当前位置:Gxlcms > JavaScript > jquery实现pc端滑动验证

jquery实现pc端滑动验证

时间:2021-07-01 10:21:17 帮助过:10人阅读

jquery实现pc端滑动验证这个插件可以放在我们的项目中使用,对jquery有兴趣的朋友可以研究研究,免费提供源码~这也是我们学习jquery的一种方法。

Q4O728Z6$6]L{XG$D~PV7V4.png

代码:

<!DOCTYPE html>
<html>
<head>

<meta charset="utf-8">
<title>PHP中文网</title>
<style type="text/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("") no-repeat center;
}
.handler_ok_bg{
    background: #fff url("") no-repeat center;
}
#drag .drag_bg{
    background-color: #7ac23c;
    height: 34px;
    width: 0px;
}
#drag .drag_text{
    position: absolute;
    top: 0px;
    width: 300px;
    -moz-user-select: none;
    -webkit-user-select: none;
    user-select: none;
    -o-user-select:none;
    -ms-user-select:none; 
}
</style>
</head>
<body>

<center><br><br><br><div id="drag"></div></center>


<script src="http://www.lanrenzhijia.com/ajaxjs/jquery.min.js"></script>

<script type="text/javascript">


/* 
 * drag 1.0
 * create by tony@jentian.com
 * date 2015-08-18
 * 拖动滑块
 */
(function($){
    $.fn.drag = function(options){
        var x, drag = this, isMove = false, defaults = {
        };
        var options = $.extend(defaults, options);
        //添加背景,文字,滑块
        var html = '<div class="drag_bg"></div>'+
                    '<div class="drag_text" onselectstart="return false;" unselectable="on">拖动滑块验证</div>'+
                    '<div class="handler handler_bg"></div>';
        this.append(html);
        
        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.mousedown(function(e){
            isMove = true;
            x = e.pageX - parseInt(handler.css('left'), 10);
        });
        
        //鼠标指针在上下文移动时,移动距离大于0小于最大间距,滑块x轴位置等于鼠标移动距离
        $(document).mousemove(function(e){
            var _x = e.pageX - x;
            if(isMove){
                if(_x > 0 && _x <= maxWidth){
                    handler.css({'left': _x});
                    drag_bg.css({'width': _x});
                }else if(_x > maxWidth){  //鼠标指针移动距离达到最大时清空事件
                    dragOk();
                }
            }
        }).mouseup(function(e){
            isMove = false;
            var _x = e.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.text('验证通过');
            drag.css({'color': '#fff'});
            handler.unbind('mousedown');
            $(document).unbind('mousemove');
            $(document).unbind('mouseup');
        }
    };
})(jQuery);


$('#drag').drag();
</script>


</div>
</body>
</html>

以上就是jquery实现pc端滑动验证的源码了,有兴趣想了解更多可以到PHP中文网首页搜索哦!

相关推荐:

jquery手风琴焦点动画

jquery标题选择动画

jQuery实现div跟随鼠标移动的代码案例

以上就是jquery实现pc端滑动验证的详细内容,更多请关注Gxl网其它相关文章!

人气教程排行