这篇文章主要介绍“微信小程序如何实现登陆注册滑块验证”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“微信小程序如何实现登陆注册滑块验证”文章能帮助大家解决问题。
具体效果如下
一、创建自定义组件MoveVerify
MoveVerify.js
Component({ /** * 组件的属性列表 */ properties: { }, /** * 组件的初始数据 */ data: { x: 0, oldx: 0, isOk: false, size: {} }, ready(){ let getSize = (selector) => { return new Promise((resolve, reject) => { let view = wx.createSelectorQuery().in(this).select(selector); view.fields({ size: true, }, (res) => { resolve(res.width); }).exec(); }); } getSize("#pathway").then((res1) => { this.data.size.pathway = res1; getSize("#track").then((res2) => { this.data.size.track = res2; }); }) }, /** * 组件的方法列表 */ methods: { onChange(e){ this.setData({ oldx: e.detail.x }) }, onEnd(){ if (this.data.isOk) { return; } if ((this.data.oldx + 1) > (this.data.size.pathway - this.data.size.track)) { this.setData({ isOk:true },()=>{ this.triggerEvent('result'); }); } else { this.setData({ x: 0, oldx: 0 }) } } } })
verification-puzzle.json
{ "component": true, "usingComponents": {} }
verification-puzzle.wxml
<view class='pathway' bindtouchend='onEnd' id='pathway'> <view class="tips"> <text wx:if="{{isOk}}" >验证通过</text> <!-- <text wx:else>拖动滑块验证</text> --> <text wx:else>请按住滑块,拖动到最右边</text> </view> <view class="track" ></view> <movable-area> <movable-view x="{{x}}" direction="horizontal" bindchange="onChange" class='{{isOk ? "active":""}}' id="track"> </movable-view> </movable-area> <view class="disabled" wx:if="{{isOk}}"></view> </view>
verification-puzzle.wxss
/* components/MoveVerify.wxss */ .pathway { height: 80rpx; width: 100%; background-color: #7ac23c; position: relative; overflow: hidden; } .pathway .tips { position: absolute; top: 0; left: 0; width: 100%; line-height: 80rpx; text-align: center; color: #666; font-size: 32rpx; z-index: 3; } .pathway .track { position: absolute; top: 0; left: 0; background-color: #eee; width: 100%; height: 100%; padding-left: 0; box-sizing: content-box; transform: translateX(0); } .pathway movable-area { position: absolute; top: 0; left: 0; height: 100%; width: 100%; background: none; z-index: 5; } .pathway movable-view { height: 100%; width: 100rpx; box-sizing: border-box; background-color: #fff; border: #ddd solid 1px; background-position: center; background-repeat: no-repeat; background-size: auto 32rpx; background-image: url(""); } .pathway movable-view.active { border: #7ac23c solid 1px; background-image: url(""); } .pathway .disabled { position: absolute; z-index: 10; height: 100%; width: 100%; top: 0; left: 0; }
二、在index页面使用
index.wxml
<move-verify bind:result="verificationResult"></move-verify>
index.js
// pages/test/test/test.js Page({ /** * 页面的初始数据 */ data: {}, verificationResult() { console.log("验证通过"); }, /** * 生命周期函数--监听页面加载 */ onLoad: function (options) { // this.randomVerification() }, /** * 生命周期函数--监听页面初次渲染完成 */ onReady: function () { }, /** * 生命周期函数--监听页面显示 */ onShow: function () { }, /** * 生命周期函数--监听页面隐藏 */ onHide: function () { }, /** * 生命周期函数--监听页面卸载 */ onUnload: function () { }, /** * 页面相关事件处理函数--监听用户下拉动作 */ onPullDownRefresh: function () { }, /** * 页面上拉触底事件的处理函数 */ onReachBottom: function () { }, /** * 用户点击右上角分享 */ onShareAppMessage: function () { } })
index.json
{ "usingComponents": { "move-verify": "/components/MoveVerify/MoveVerify", } }