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 相关文章推荐
FileUpload 控件 禁止手动输入或粘贴的实现代码
Apr 07 Javascript
特殊情况下如何获取span里面的值
May 20 Javascript
javascript实现限制上传文件大小
Feb 06 Javascript
基于JavaScript实现手机短信按钮倒计时(超简单)
Dec 30 Javascript
Easyui在treegrid添加控件的实现方法
Jun 23 Javascript
vue mixins组件复用的几种方式(小结)
Sep 06 Javascript
Angular2+如何去除url中的#号详解
Dec 20 Javascript
vuejs实现ready函数加载完之后执行某个函数的方法
Aug 31 Javascript
详解原生JS动态添加和删除类
Mar 26 Javascript
Node.js API详解之 tty功能与用法实例分析
Apr 27 Javascript
Vue如何基于vue-i18n实现多国语言兼容
Jul 17 Javascript
vue实现标签云效果的示例
Nov 09 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
用PHP实现维护文件代码
2007/06/14 PHP
浅谈php命令行用法
2015/02/04 PHP
php分割合并两个字符串的函数实例
2015/06/19 PHP
php实现的操作excel类详解
2016/01/15 PHP
setTimeout与setInterval在不同浏览器下的差异
2010/01/24 Javascript
基于jQuery实现的百度导航li拖放排列效果,即时更新数据库
2012/07/31 Javascript
一个仿糯米弹框效果demo
2014/07/22 Javascript
浅谈jquery事件处理
2015/04/24 Javascript
javascript常用的方法分享
2015/07/01 Javascript
JavaScript判断IE版本型号
2015/07/27 Javascript
javascript+HTML5的Canvas实现Lab单车动画效果
2015/08/07 Javascript
jQuery插件开发精品教程让你的jQuery提升一个台阶
2016/01/27 Javascript
JS创建事件的三种方法(实例代码)
2016/05/12 Javascript
JavaScript数组方法大全(推荐)
2016/07/05 Javascript
JS给swf传参数的实现方法
2016/09/13 Javascript
JS动态的把左边列表添加到右边的实现代码(可上下移动)
2016/11/17 Javascript
详解angular中通过$location获取路径(参数)的写法
2017/03/21 Javascript
vue-resource调用promise取数据方式详解
2017/07/21 Javascript
js 奇葩技巧之隐藏代码
2017/08/11 Javascript
Vue中的ref作用详解(实现DOM的联动操作)
2017/08/21 Javascript
node.js 利用流实现读写同步,边读边写的方法
2017/09/11 Javascript
基于JS实现html中placeholder属性提示文字效果示例
2018/04/19 Javascript
Vue中常用rules校验规则(实例代码)
2019/11/14 Javascript
[39:21]LGD vs OG 2019国际邀请赛淘汰赛 胜者组 BO3 第二场 8.24
2019/09/10 DOTA
[01:00:13]完美世界DOTA2联赛 LBZS vs Forest 第一场 11.07
2020/11/09 DOTA
Python爬虫框架Scrapy安装使用步骤
2014/04/01 Python
跟老齐学Python之变量和参数
2014/10/10 Python
python socket 聊天室实例代码详解
2019/11/14 Python
matplotlib阶梯图的实现(step())
2021/03/02 Python
5 个强大的HTML5 API 函数推荐
2014/11/19 HTML / CSS
英国外籍人士的在线超市:British Corner Shop
2019/06/03 全球购物
史学专业毕业生求职信
2014/05/09 职场文书
安全教育观后感
2015/06/17 职场文书
mysql中数据库覆盖导入的几种方式总结
2022/03/25 MySQL
Z-Order加速Hudi大规模数据集方案分析
2022/03/31 Servers
JS实现九宫格拼图游戏
2022/06/28 Javascript