资讯专栏INFORMATION COLUMN

仿支付宝滑块验证码效果的手机端实现

android_c / 3558人阅读

摘要:为了加强验证功能,减少的被攻击。队长要求做一个支付宝的滑块验证效果。通过查找大多数案例都是端展示效果,在手机端并不能友好展示。原文链接仿支付宝滑块验证码效果的前端实现展示效果图滑块效果的前端实现。

为了加强验证功能,减少APP的被攻击。队长要求做一个支付宝的滑块验证效果。除了它外观和用户体验上的优秀外,它的安全性并未降低,通过对用户行为的分析保证了安全校验。

通过查找大多数案例都是PC端展示效果,在手机端并不能友好展示。于是参考一位CSND博主的文章进行了一些修改。

原文链接 CSDN-仿支付宝滑块验证码效果的前端实现

展示效果图:

滑块效果的前端实现。涵盖的内容主要: 滑块前端样式(html排版),滑块的闪光移动效果(CSS3 动画),以及滑块滑动脚本的编写(javascript 按住,拖动,离开事件的编写。)

备注: 本实例HTML、CSS并无改动,只有 JS 的修改。

HTMl代码



    
    滑动
    
    
    
    


请按住滑块,拖动到最右边
CSS代码
#drag{
    position: relative;
    background-color: #e8e8e8;
    width: 300px;
    height: 34px;
    line-height: 34px;
    text-align: center;
}
#drag .handler{
    position: absolute;
    top: 0px;
    left: 0px;
    width: 40px;
    height: 32px;
    border: 1px solid #ccc;
    cursor: move;
}
.handler_bg{
    background: #fff url("../img/slider.png") no-repeat center;
}
.handler_ok_bg{
    background: #fff url("../img/complet.png") no-repeat center;
}
#drag .drag_bg{
    background-color: #7ac23c;
    height: 34px;
    width: 0px;
}
#drag .drag_text{
    position: absolute;
    top: 0px;
    width: 300px;
    color:#9c9c9c;
    -moz-user-select: none;
    -webkit-user-select: none;
    user-select: none;
    -o-user-select:none;
    -ms-user-select:none;
    font-size: 12px;        //  add
}


JS代码

备注: 本实例HTML、CSS并无改动,只有 JS 的修改。

1、将鼠标按下,移动,松开事件 换成 按住开始,按住移动,按住结束
2、定义手指所放在元素上的位置,来获取pageX
3、取消事件绑定 off()

$.fn.drag = function(options) {
    var x, drag = this, isMove = false, defaults = {
    };
    var options = $.extend(defaults, options);
    var handler = drag.find(".handler");
    var drag_bg = drag.find(".drag_bg");
    var text = drag.find(".drag_text");
    var maxWidth = drag.width() - handler.width();  //能滑动的最大间距

    //触摸屏幕时候的x轴的位置
    handler.on("touchstart",function(e) {
        e.preventDefault();
        isMove = true;
        var _touch = e.originalEvent.targetTouches[0];// 把元素放在手指所在的位置
        x = _touch.pageX - parseInt(handler.css("left"), 10);

    })
    //滑块在移动时,移动距离大于0小于最大间距,滑块x轴位置等于滑块移动距离
    .on("touchmove",function(e) {
            e.preventDefault();
            var _touch = e.originalEvent.changedTouches[0];
            var _x = _touch.pageX - x;// _x = e.pageX - (e.pageX - parseInt(handler.css("left"), 10)) = x
            if (isMove) {
            if (_x > 0 && _x <= maxWidth) {
                handler.css({"left": _x});
                drag_bg.css({"width": _x});
            } else if (_x > maxWidth) {  //鼠标指针移动距离达到最大时清空事件
                dragOk();
            }
        }
    })
    //离开触摸屏幕时,判断位置
    .on("touchend", function(e) {
            e.preventDefault();
            isMove = false;
            var _touch = e.originalEvent.changedTouches[0];
            var _x = _touch.pageX - x;
            if (_x < maxWidth) { //松开滑块时,如果没有达到最大距离位置,滑块就返回初始位置
            handler.css({"left": 0});
            drag_bg.css({"width": 0});
        }
    });

    //清空事件
    function dragOk() {
        handler.removeClass("handler_bg").addClass("handler_ok_bg");
        text.removeClass("slidetounlock").text("验证通过").css({"color":"#fff"});       //modify
        // drag.css({"color": "#fff !important"});

        handler.css({"left": maxWidth});                   // add
        drag_bg.css({"width": maxWidth});                  // add

        //注意取消绑定的事件
        handler.off("touchstart");
        handler.off("touchmove");
        handler.off("touchend");
    }
};    

如有问题,欢迎大家交流指正。QQ:1357912285

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/52185.html

相关文章

  • 移动开发IOS 6PLUS中表单输入造成页面高度缩小bug

    摘要:出现的地方就是在上滑块无法拖动,经过检测发现是在上有这个问题。弹窗是通过定位在页面上的。当表单激活的时候,由于手机自带的输入法弹起造成页面向上滚动,会隐藏页面顶部一部分。解决方法通过的事件改变的值为。记录一下开发终于到的问题。 先说下业务逻辑:登录页面,滑块验证,手机号码输入完成以后,会有一个滑块验证,验证正确则会收到短信验证码。这就是这个登录页面的基本逻辑。 showImg(http...

    nevermind 评论0 收藏0
  • 移动开发IOS 6PLUS中表单输入造成页面高度缩小bug

    摘要:出现的地方就是在上滑块无法拖动,经过检测发现是在上有这个问题。弹窗是通过定位在页面上的。当表单激活的时候,由于手机自带的输入法弹起造成页面向上滚动,会隐藏页面顶部一部分。解决方法通过的事件改变的值为。记录一下开发终于到的问题。 先说下业务逻辑:登录页面,滑块验证,手机号码输入完成以后,会有一个滑块验证,验证正确则会收到短信验证码。这就是这个登录页面的基本逻辑。 showImg(http...

    jokester 评论0 收藏0
  • 移动开发IOS 6PLUS中表单输入造成页面高度缩小bug

    摘要:出现的地方就是在上滑块无法拖动,经过检测发现是在上有这个问题。弹窗是通过定位在页面上的。当表单激活的时候,由于手机自带的输入法弹起造成页面向上滚动,会隐藏页面顶部一部分。解决方法通过的事件改变的值为。记录一下开发终于到的问题。 先说下业务逻辑:登录页面,滑块验证,手机号码输入完成以后,会有一个滑块验证,验证正确则会收到短信验证码。这就是这个登录页面的基本逻辑。 showImg(http...

    guqiu 评论0 收藏0
  • Vue2.0 仿滴滴出行项目

    摘要:仿滴滴出行项目最近,各大社区出现很多小伙伴的项目,趁着这股热潮我也用撸了一个滴滴出行的项目。可是,后来在手机上发现,输入的时候居然调不出软键盘,写项目的时候没考虑到设备问题,简直是大大的失误。也就是说可以在组件内部进行请求,不需要提交。 Vue2.0 仿滴滴出行项目 最近,各大社区出现很多小伙伴的vue项目,趁着这股热潮我也用vue撸了一个滴滴出行的项目。 效果预览 showImg(h...

    ShevaKuilin 评论0 收藏0

发表评论

0条评论

最新活动
阅读需要支付1元查看
<