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 相关文章推荐
window.location.hash 属性使用说明
Mar 20 Javascript
jQuery '行 4954 错误: 不支持该属性或方法' 的问题解决方法
Jan 19 Javascript
js中获取事件对象的方法小结
Mar 13 Javascript
jQuery操作Select选择的Text和Value(获取/设置/添加/删除)
Mar 06 Javascript
gridpanel动态加载数据的实例代码
Jul 18 Javascript
javascript比较两个日期的先后示例代码
Dec 31 Javascript
javascript删除元素节点removeChild()用法实例
May 26 Javascript
深入理解JavaScript编程中的原型概念
Jun 25 Javascript
JavaScript实现图片自动加载的瀑布流效果
Apr 11 Javascript
使用VueCli3+TypeScript+Vuex一步步构建todoList的方法
Jul 25 Javascript
JS检测浏览器开发者工具是否打开的方法详解
Oct 02 Javascript
详解CocosCreator消息分发机制
Apr 16 Javascript
解决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
PHP4实际应用经验篇(2)
2006/10/09 PHP
php实现的在线人员函数库
2008/04/09 PHP
php模板中出现空行解决方法
2011/03/08 PHP
自编函数解决pathinfo()函数处理中文问题
2014/11/03 PHP
PHP的APC模块实现上传进度条
2015/10/27 PHP
CL vs ForZe BO5 第二场 2.13
2021/03/10 DOTA
JavaScript国旗变换效果代码
2008/08/13 Javascript
jquery 输入框数字限制插件
2009/11/10 Javascript
Ext grid 添加右击菜单
2009/11/26 Javascript
Javascript load Page,load css,load js实现代码
2010/03/31 Javascript
两种简单实现菜单高亮显示的JS类代码
2010/06/27 Javascript
jquery ajax请求实例深入解析
2012/11/26 Javascript
js浮动图片的动态效果
2013/07/10 Javascript
js清理Word格式示例代码
2014/02/13 Javascript
JQuery下拉框应用示例介绍
2014/04/23 Javascript
js中的for如何实现foreach中的遍历
2014/05/31 Javascript
JS实现可直接显示网页代码运行效果的HTML代码预览功能实例
2015/08/06 Javascript
JavaScript使ifram跨域相互访问及与PHP通信的实例
2016/03/03 Javascript
javascript中错误使用var造成undefined
2016/03/31 Javascript
js 实现省市区三级联动菜单效果
2017/02/20 Javascript
详解vue移动端项目的适配(以mint-ui为例)
2018/08/17 Javascript
在layui中layer弹出层点击事件无效的解决方法
2019/09/05 Javascript
python连接远程ftp服务器并列出目录下文件的方法
2015/04/01 Python
利用Python的装饰器解决Bottle框架中用户验证问题
2015/04/24 Python
Python 搭建Web站点之Web服务器与Web框架
2016/11/06 Python
Django框架教程之正则表达式URL误区详解
2018/01/28 Python
Python从使用线程到使用async/await的深入讲解
2018/09/16 Python
对Python w和w+权限的区别详解
2019/01/23 Python
Python之pymysql的使用小结
2019/07/01 Python
Python + Flask 实现简单的验证码系统
2019/10/01 Python
法国综合购物网站:RueDuCommerce
2016/09/12 全球购物
一封普通求职者的求职信
2013/11/20 职场文书
车间调度岗位职责
2013/11/30 职场文书
公司成立感言
2014/01/11 职场文书
公证书标准格式
2014/04/10 职场文书
MySQL新手入门进阶语句汇总
2022/09/23 MySQL