实现一个滑块验证功能
程序员文章站
2022-04-14 13:43:38
...
最近写了点小东西一个滑动验证
<html> <head> <meta charset="UTF-8"> <title></title> <style type="text/css"> *{ margin: 0px; padding: 0px; } body{ background: #000000; } .sliding{ width: 400px; height: 40px; margin: 50px auto; background: #ccc; text-align: center; line-height: 40px; position: relative; } .sliding > p{ width: 0px; height: 100%; position: absolute; top: 0; left: 0; background: green; z-index: 99; color: #FFFFFF; text-align: center; overflow: hidden; } .sliding > span{ display: block; width: 46px; height: 100%; position: absolute; top: 0; left: 0; background-size: cover; cursor: pointer; z-index: 999; } .span1_back{ background: url(img/sli1.png) no-repeat center center; } .span2_back{ background: url(img/sli2.png)no-repeat center center; } </style> </head> <body> <p class="sliding"> 请按住滑块,拖至最右侧。 <p></p> <span class="span1_back"> </span> </p> <!-- 布局方面主要是使用定位把p标签和span都定位在 p 左边 -->
<script src="js/jquery.js" type="text/javascript" charset="utf-8"></script> <script type="text/javascript"> $(function(){ $('.sliding > span').on('mousedown',function(ev){ var down_X=ev.clientX; //获取鼠标摁下的位置 var p_W=$('.sliding > p').get(0).offsetWidth; //获取p的宽度当然这其实这个可有可无 var span_X=$('.sliding > span').get(0).offsetLeft; //与上同理 $(document).get(0).onmousemove=function(ev){ var move_X=ev.clientX; //获取鼠标移动的位置 var size = move_X - down_X + p_W; //用移动过后的位置减去鼠标摁下的位置加上p的宽度或者 span 的left 值 因为俩者是同步的 所以 减去 其中一个就好 if(size>0){// 移动的时候判断size>0的时候执行,Math.min选取最小值,让拖动过程中不至于超出 size=Math.min(($('.sliding').get(0).offsetWidth - $('.sliding > span').get(0).offsetWidth),size); }else{ //小于0的时候 size =0; 防止有无聊的用户拖回 超出边界。 size=0; } $('.sliding > p').css('width', size + 'px'); $('.sliding > span').css('left', size + 'px'); return false;//防止拖拽过程中选中文字 } $(document).get(0).onmouseup=function(){ //鼠标松开执行
//判段span到达边界时候执行 if(($('.sliding > span').get(0).offsetLeft) >= ($('.sliding').get(0).offsetWidth - $('.sliding > span').get(0).offsetWidth)){ $('.sliding > span').attr('class','span2_back'); //更改span的背景图片 $('.sliding > p').text('验证通过'); //更改p标签中的内容 $('.sliding > span').off('mousedown');//删除鼠标摁下方法防止用户 无聊往回 推拽 }else{//判断没到达边界让它再回到起点 $('.sliding > span').animate({left:'0px'},300); //利用jquery让p 和 span 回到起始状态 $('.sliding > p').animate({width:'0px'},300); } $(document).get(0).onmousemove=null; //最后让 鼠标移动 和 鼠标松开 事件停止 $(document).get(0).onmouseup=null; } }) }) </script> </body> </html>
以上就是实现一个滑块验证功能的详细内容,更多请关注其它相关文章!
推荐阅读
-
springboot整合shiro多验证登录功能的实现(账号密码登录和使用手机验证码登录)
-
不要框架,纯PHP,能实现这样的功能吗?有很多页面,有插入删除修改功能,只写一种增删改方法,其他页面也能共用这一个方法
-
用户注册功能:输入验证码后点击空处,自动核对输入的验证码是否正确。如果正确,在验证码框框后面显示一个绿色的对勾
-
ThinkPHP实现带验证码的文件上传功能实例
-
ASP.NET jQuery 实例12 通过使用jQuery validation插件简单实现用户注册页面验证功能_jquery
-
怎么利用php实现中文验证码的功能
-
在ecshop的购物流程页,商品列表加一个复选框,并实现与之相对应功能的代码,该怎么处理
-
S2SH整合JQuery+Ajax实现登录验证功能实现代码_jquery
-
求实现一个表单跟IFrame引用网站之间传值功能
-
Node.js开发教程之基于OnceIO框架实现文件上传和验证功能