js实现滑动滑块验证登录


Posted in Javascript onJuly 24, 2020

本文实例为大家分享了js实现滑动滑块验证登录的具体代码,供大家参考,具体内容如下

1.html代码

<div class="box">
 <!--滑块-->
 <a href="#" rel="external nofollow" ><div class="btn">>></div></a>
 <!--文字-->
 <p class="text">拖动滑块验证</p>
 <!--背景-->
 <div class="bg"></div> 
</div>

2.css样式

最大的盒子相对定位,其他内部内容绝对定位
需要根据层级设置z-index保证滑动的正常使用

.box{
 position: relative;
 width: 300px;
 height: 34px;
 background: #e8e8e8;
 border-radius: 4px;
 left: 20px;
}
.btn{
 position: absolute;
 top: 0;
 width: 40px;
 height:32px;
 text-align: center;
 line-height: 32px;
 border-radius: 4px;
 z-index: 3;
 background-color: #fff;
 border: 1px solid #ccc;
 color: black;
}
.text{
 position: absolute;
 width: 100%;
 margin: 0;
 text-align: center;
 line-height: 34px;
 display: block;
 z-index: 2;
 /*-webkit-margin-before: 1em;
 -webkit-margin-after: 1em;*/
}
.bg{
 position: absolute;
 height: 100%;
 background-color: yellowgreen;
 z-index: 1;
}

样式

js实现滑动滑块验证登录

3.js事件

分析使用过程:按住滑块并拖动可以移动,中途松开滑块返回起始位置,拖动至最后滑块不动
分析动作:
1.按钮按下并移动
2.事件状态:event对象(鼠标位置)event.clientX获得与X轴的距离
3.松开按钮回到原处
4.结束,松开按钮,按钮不可再次拖动

1)

var btn=document.querySelector(".btn");
var box=document.querySelector(".box");
var bg=document.querySelector(".bg");
var text=document.querySelector(".text");

或者使用封装选择器

function $(name){
  return document.querySelector(name);
};
 var box=$(".box"),btn=$(".btn").....;

2)按下

按下后获得与x轴的距离

btn.onmousedown=function(e){
  var downX=e.clientX;

3)拖动

拖动后获得与x轴距离减去初始值距离得到按钮移动的值
根据移动的值:判断按钮是否可以正常移动,判断按钮是否已经完成验证

btn.onmousemove=function(e){
 var moveX=e.clientX-downX; 
// console.log(moveX);
 
 //移动范围
 if(moveX>-2){
 this.style.left=moveX+"px";//将移动值赋值给滑块
 bg.style.width=moveX+"px";//背景
 if(moveX>=(box.offsetWidth-btn.offsetWidth)){//包含原始宽度内边距边框,不包含外边框
 //拖到头,验证成功
 flag=true;
 text.innerHTML="验证成功";
 text.style.color="white";
 //事件清除
 btn.onmousedown=null;
 btn.onmousemove=null;
 }
 }

4)松开按钮

回到原处清除拖动

btn.onmouseup=function(){ 
 //事件清除
  btn.onmousemove=null;
  if(flag)return;
  this.style.left=0;//将移动值赋值给滑块
 bg.style.width=0;//背景
 
 }

4.效果

js实现滑动滑块验证登录

5.源码

//原生写法
window.onload=function(){
 var btn=document.querySelector(".btn");
 var box=document.querySelector(".box");
 var bg=document.querySelector(".bg");
 var text=document.querySelector(".text");
 //封装选择器
// function $(name){
// return document.querySelector(name);
// };
// var box=$(".box"),btn=$(".btn").....;
 var flag=false;
 //按下onmousedown 拖动onmousemove
 //document.querySelector(".btn").onmousedown=function(event){//event事件状态
// var e=event||window.event;
 //获取方法集合,可直接通过id, 类, 类型, 属性, 属性值等来选取元素(返回此名字的第一个)。
 btn.onmousedown=function(e){//按下
  var downX=e.clientX; //按下后对x轴的距离
//  console.log(downX);
//  alert("1");
 
 btn.onmousemove=function(e){//拖动
 var moveX=e.clientX-downX; //拖动后与x轴距离减去初始值距离,移动值
// console.log(moveX);
 
 //移动范围
 if(moveX>-2){
 this.style.left=moveX+"px";//将移动值赋值给滑块
 bg.style.width=moveX+"px";//背景
 if(moveX>=(box.offsetWidth-btn.offsetWidth)){//包含原始宽度内边距边框,不包含外边框
 //拖到头,验证成功
 flag=true;
 text.innerHTML="验证成功";
 text.style.color="white";
 //事件清除
 btn.onmousedown=null;
 btn.onmousemove=null;
 }
 }
 }
 }
 
 //松开按钮
 btn.onmouseup=function(){ 
 //事件清除
  btn.onmousemove=null;
  if(flag)return;
  this.style.left=0;//将移动值赋值给滑块
 bg.style.width=0;//背景
 
 }
}

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
javascript打开新窗口同时关闭旧窗口
Jan 16 Javascript
js 使FORM表单的所有元素不可编辑的示例代码
Oct 17 Javascript
jQuery实现表格行上下移动和置顶效果
Jun 05 Javascript
javaScript中slice函数用法实例分析
Jun 08 Javascript
jQuery EasyUI Dialog拖不下来如何解决
Sep 28 Javascript
AngularJs ng-route路由详解及实例代码
Sep 14 Javascript
微信小程序 获取相册照片实例详解
Nov 16 Javascript
基于js中document.cookie全面解析
Sep 14 Javascript
vue+vuecli+webpack中使用mockjs模拟后端数据的示例
Oct 24 Javascript
原生js实现贪食蛇小游戏的思路详解
Nov 26 Javascript
JavaScript canvas实现跟随鼠标移动小球
Feb 09 Javascript
解决vue中provide inject的响应式监听
Apr 19 Vue.js
解决VUEX的mapState/...mapState等取值问题
Jul 24 #Javascript
对vuex中store和$store的区别说明
Jul 24 #Javascript
小程序实现简单语音聊天的示例代码
Jul 24 #Javascript
浅谈Vuex的this.$store.commit和在Vue项目中引用公共方法
Jul 24 #Javascript
vue中全局路由守卫中替代this操作(this.$store/this.$vux)
Jul 24 #Javascript
javascript实现支付宝滑块验证码效果
Jul 24 #Javascript
解决父组件将子组件作为弹窗调用只执行一次created的问题
Jul 24 #Javascript
You might like
在SAE上搭建最新wordpress的方法
2014/12/21 PHP
PHP CodeIgniter框架的工作原理研究
2015/03/30 PHP
[原创]php使用curl判断网页404(不存在)的方法
2016/06/23 PHP
基于PHP常用文件函数和目录函数整理
2017/08/17 PHP
推荐一些非常不错的javascript学习资源站点
2007/08/29 Javascript
js数组转json并在后台对其解析具体实现
2013/11/20 Javascript
一个字符串反转函数可实现字符串倒序
2014/09/15 Javascript
浅谈JS继承_寄生式继承 &amp; 寄生组合式继承
2016/08/16 Javascript
如何用js判断dom是否有存在某class的值
2017/02/13 Javascript
jquery实现tab键进行选择后enter键触发click行为
2017/03/29 jQuery
jQuery使用unlock.js插件实现滑动解锁
2017/04/04 jQuery
jquery radio 动态控制选中失效问题的解决方法
2018/02/28 jQuery
Vue绑定内联样式问题
2018/10/17 Javascript
[02:51]DOTA2 2015国际邀请赛中国区预选赛第一日战报
2015/05/27 DOTA
Python写的英文字符大小写转换代码示例
2015/03/06 Python
Python检测一个对象是否为字符串类的方法
2015/05/21 Python
Python读取网页内容的方法
2015/07/30 Python
Python中遍历字典过程中更改元素导致异常的解决方法
2016/05/12 Python
python 队列详解及实例代码
2016/10/18 Python
使用Python的Scrapy框架十分钟爬取美女图
2016/12/26 Python
numpy中矩阵合并的实例
2018/06/15 Python
基于DataFrame改变列类型的方法
2018/07/25 Python
使用pytorch进行图像的顺序读取方法
2018/07/27 Python
Pytorch中实现只导入部分模型参数的方式
2020/01/02 Python
Python基于locals返回作用域字典
2020/10/17 Python
为奢侈时尚带来了慈善元素:Olivela
2018/09/29 全球购物
希腊品牌鞋类销售网站:epapoutsia.gr
2020/03/18 全球购物
应届护士推荐信
2013/11/16 职场文书
普通院校学生的自荐信
2013/11/27 职场文书
大专生的学习自我评价
2013/12/04 职场文书
工作疏忽、懈怠的检讨书
2014/09/11 职场文书
公司合作协议范文
2014/10/01 职场文书
仓管员岗位职责范本
2015/04/01 职场文书
解决SpringBoot跨域的三种方式
2021/06/26 Java/Android
Java中Quartz高可用定时任务快速入门
2022/04/03 Java/Android
win11无法登录onedrive错误代码0x8004def7怎么办 ?
2022/04/05 数码科技