vue登录人机校验--图片旋转验证

  1. login.vue文件
<template>
	<!-- 图片旋转 -->
	<uni-popup ref="visible" style="background-color: antiquewhite;">
		<!--子组件-->
		<picturesRotating :visible.sync="true" @result="result" :maskClick="maskClick" />
	</uni-popup>
</template>
<script>
import picturesRotating from '../../components/piaoyi-picturesRotating/piaoyi-picturesRotating.vue'
export default {
	components:{
		picturesRotating
	},
	data(){
		return{
			maskClick: true
		}
	},
	methods:{
		result(e) {
			this.verivyIs = e
			if (e) {
				this.$refs.visible.close()
			}
		}
	}
}
</script>
  1. piaoyi-picturesRotating.vue 文件
<template>
	<view class="piaoyi-picturesRotating">
		<view class="picturesRotating" v-if="visible">
			<view class="title">
				人工验证
			</view>
			<view class="mintitle">
				滑动滑块,使图片显示角度为正
			</view>
			<view class="detail" :class="{'detailactive' : detail == '验证失败,请重试'}">
				{{detail ? detail : ''}}
			</view>
			<view class="imgbox" :style="'transform: rotate(' + deg + 'deg);'">
				<image v-if="imgurl" :src="imgurl" mode=""></image>
			</view>
			<view class="movablebox">
				<movable-area>
					<movable-view @touchstart="touchstart" @touchend="touchend" :disabled="disabled" direction="horizontal" :x="x" @change="onchange">
						<image :src="icon" mode=""></image>
					</movable-view>
				</movable-area>
			</view>
		</view>
		<view @tap="close" @touchmove.stop.prevent :class="visible ? 'pupop-model' : 'pupop-models'"></view>
	</view>
</template>

<script>
	export default {
		data() {
			return {
				x: 0,
				startDeg: 0,
				deg: 0,
				isPass: false,
				timer: null,
				disabled: false,
				detail: '',
				imgurl: '',
				imgList: [
					'https://ts2.cn.mm.bing.net/th?id=OIP-C.7DoQwd5S5Uo010esfn9ZAQAAAA&w=250&h=250&c=8&rs=1&qlt=90&o=6&dpr=1.3&pid=3.1&rm=2',
					'https://tse1-mm.cn.bing.net/th/id/OIP-C.keLuuLXa1_XmRhJiQjwZFgAAAA?w=202&h=202&c=7&r=0&o=5&dpr=1.3&pid=1.7',
					'https://tse4-mm.cn.bing.net/th/id/OIP-C.HNCroQQ0lGlvJTs4ZELojwAAAA?w=202&h=202&c=7&r=0&o=5&dpr=1.3&pid=1.7',
					'https://ts1.cn.mm.bing.net/th?id=OIP-C.UgVPqAbA56SxLMox5_4A9QHaHa&w=250&h=250&c=8&rs=1&qlt=90&o=6&dpr=1.3&pid=3.1&rm=2'
				]
			}
		},
		props: {
			visible: {
				type: Boolean,
				default: false
			},
			maskClick: {
				type: Boolean,
				default: true
			},
			icon: {
				type: String,
				default: ""
			}
		},
		mounted() {
			this.start()
		},
		watch: {
			visible: function() {
				this.detail = ''
				this.start()
			}
		},
		methods: {
			touchstart(e) {
			},
			touchend(e) {
				if (this.isPass) {
					this.disabled = true
					this.detail = '验证成功,2秒后自动关闭'
					setTimeout(() => {
						this.close()
						this.$emit('result', this.isPass)
					}, 2000)
				} else {
					this.detail = '验证失败,请重试'
					this.start()
				}
			},
			onchange(e) {
				var x = e.detail.x + this.startDeg
				this.deg = x
				var isPass = false
				if (Math.abs((this.startDeg + x) % 360) - this.startDeg > -10 && Math.abs((this.startDeg + x) % 360) - this.startDeg < 10) {
					isPass = true
				}
				this.isPass = isPass
			},
			start() {
				var index = this.random(0, 2)
				this.imgurl = this.imgList[index]
				console.log(this.imgurl)
				var deg = this.random(240, 300)
				this.deg = deg
				this.startDeg = deg
				this.x = this.x == 0 ? 0.1 : 0
				this.disabled = false
			},
			close() {
				if (!this.maskClick) return
				this.$emit('update:visible', false)
				this.disabled = false
			},
			random(min, max) {
			    return Math.floor(Math.random() * (max - min)) + min;
			}
		}
	}
</script>

<style lang="scss" scoped>
	.piaoyi-picturesRotating {
		.pupop-model {
			position: fixed;
			left: 0;
			top: 0;
			width: 100%;
			height: 100%;
			z-index: 100;
			background: rgba(0, 0, 0, .5);
		}
		.pupop-models{
			display: none;
		}
		.title {
			text-align: center;
			font-size: 32rpx;
			line-height: 32rpx;
			padding-top: 30rpx;
			color: #999;
		}
		.mintitle {
			text-align: center;
			font-size: 36rpx;
			line-height: 36rpx;
			font-weight: 700;
			color: #333;
			padding: 20rpx 0;
		}
		.detail {
			text-align: center;
			font-size: 32rpx;
			color: #666;
			line-height: 32rpx;
			padding-bottom: 15rpx;
		}
		.detailactive {
			color: red;
		}
		.picturesRotating {
			position: fixed;
			width: 600rpx;
			height: 800rpx;
			border-radius: 30rpx;
			left: 0;
			right: 0;
			top: 0;
			bottom: 0;
			margin: auto;
			z-index: 120;
			background: #fff;
		}
		.imgbox {
			margin: 30rpx 0;
			display: flex;
			justify-content: center;
			align-items: center;
			image {
				width: 400rpx;
				height: 400rpx;
				border-radius: 100%;
			}
		}
		.movablebox {
			padding: 0 50rpx;
			movable-area {
				height: 100rpx;
				width: 100%;
				border-radius: 100rpx;
				background: #f3f9f1;
				border: 2rpx solid rgba(0,163,68,0.3);
				movable-view {
					width: 80rpx;
					height: 80rpx;
					border-radius: 100%;
					padding: 10rpx;
					image {
						width: 100%;
						height: 100%;
					}
				}
			}
		}
	}
</style>
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值