微信小程序实现滑块验证
短信预约 -IT技能 免费直播动态提醒
本文实例为大家分享了微信小程序实现滑块验证的具体代码,供大家参考,具体内容如下
思路:
1.手指按住 并且 还能 滑动
2.滑动到一定的距离 进行判断
百度微信开发者文档 : 使用 movable-view的可移动区域。 结合 movable-view
wxml代码
<movable-area class="content" style="width:{{area_width}}%">拖动滑块验证
<movable-view class='box' style='width:{{box_width}}rpx' friction="{{100}}" direction="horizontal" x="{{x}}" damping="{{500}}" bindchange="drag" bindtouchend="dragOver">
<view class='movable-icon'></view>
</movable-view>
</movable-area>
wxjs
var coord; //声明 全局变量
// data里面的数据
x: 0,
area_width: 85, //可滑动区域的宽,单位是百分比,设置好后自动居中
box_width: 120, //滑块的宽,单位是 rpx
maxNum: 0,
// 函数方法
drag(e) {
var that = this;
coord = e.detail.x; //根据bindchange 事件获取detail的x轴
},
dragOver(e) { //根据触摸 手指触摸动作结束 判断 当前的x轴 是否大于预设值的值
var that = this;
if (coord >= that.data.maxNum) {
wx.showToast({
title: '验证成功',
icon: 'success',
duration: 2000
})
//验证成功之后的代码
} else { // 如果不大于 则设置 x周的距离为0
that.setData({
x: 0,
})
}
},
onLoad: function (e) {
var that = this;
wx.getSystemInfo({ //获取系统信息 设置预设值
success: function (res) {
console.log(res.windowWidth);
var n = Math.floor(res.windowWidth * that.data.area_width / 100 - that.data.box_width / 2)
console.log(n)
that.setData({
maxNum: n,
})
}
})
},
.content{
margin: 0 auto;
margin-top: 200rpx;
height: 90rpx;
background: #ededed;
color: #666;
border-radius: 10px;
display:flex;
justify-content:center;
align-items:center;
font-size:16px;
}
.box{
height: 90rpx;
background-color: #fc5b13;
border-radius: 10px;
display: flex;
justify-content: center;
align-items: center;
}
.movable-icon{
width: 60rpx;
height: 60rpx;
background: url() no-repeat center center;
background-size: 100% 100%;
}
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持编程网。
免责声明:
① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。
② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341