zoukankan      html  css  js  c++  java
  • js/vue实现滑块验证(方法3)

    html代码:

    <div v-if="showUpdatVerify">
         <div class="drag" >
               <div class="drag_bg"></div>
               <div class="drag_text">{{confirmWords}}</div>
               <div @mousedown="mousedownFn($event)" class="handler handler_bg"></div>
         </div>
    </div>

    data中定义:

    beginClientX: 0,
    /*距离屏幕左端距离*/
    mouseMoveStata: false,
    /*触发拖动状态 判断*/
    max 350,  //  单位:px
    /*拖动最大宽度,依据滑块宽度算出来的*/
    confirmWords: '请按住滑块,拖动到最右边',
    /*滑块文字*/
    confirmSuccess: false, /*验证成功判断*/

     引入jquery包:

    <script src="http://libs.baidu.com/jquery/2.1.4/jquery.min.js"></script>

    js代码:

            mousedownFn: function(e) {
                this.mouseMoveStata = true;
                this.beginClientX = e.clientX;
            }, //按下滑块函数 
            successFunction() {
                $(".handler").removeClass('handler_bg').addClass('handler_ok_bg');
                this.confirmWords = '验证通过';
                this.slideSuccess = true;   //  验证成功与否的状态,以便后续操作
                $(".drag").css({
                    'color': '#fff'
                });
                $(".drag").css({
                    'background-color': '#4092ff'
                });
                $(".handler").css({
                    'left': this.maxwidth-40
                });
                $(".drag_bg").css({
                    'width': this.maxwidth-40
                });
                $('body').unbind('mousemove');
                $('body').unbind('mouseup');
                this.confirmSuccess = true;
            }, //验证成功函数 
            updateSlide(){   //  滑块执行方法,根据需要执行;若是页面进入就显示,则可以写在mounted()生命周期中
                // 滑块3
                $('body').on('mousemove', (e) => {
                    //拖动,这里需要用箭头函数,不然this的指向不会是vue对象 
                    if(this.mouseMoveStata) {
                        var width = e.clientX - this.beginClientX;      //  滑块滑动长度
                        if(width > 0 && width <= (this.maxwidth-40)) {   
                            $(".handler").css({
                                'left': width
                            });
                            $(".drag_bg").css({
                                'width': width
                            });
                        } else if(width > (this.maxwidth-40)) {
                            this.successFunction();
                        }
                    }
                });
                $('body').on('mouseup', (e) => {
                    //鼠标放开 
                    this.mouseMoveStata = false;
                    var width = e.clientX - this.beginClientX;
                    if(width < this.maxwidth) {
                        $(".handler").css({
                            'left': 0
                        });
                        $(".drag_bg").css({
                            'width': 0
                        });
                    }
                })
            }

    css代码:

    .drag {
        position: relative;
        background-color: #e8e8e8;
         6.5rem;
        height: 50px;
        margin-top: 100px;
        line-height: 50px;
        text-align: center;
        font-size: 16px;
       }
       .handler {
        position: absolute;
        top: 0px;
        left: 0px;
         0.75rem;
        height: 50px;
        border: 1px solid #ccc;
        cursor: move;
       }
       .handler_bg {
        background: #fff url("") no-repeat center;
       }
       .handler_ok_bg {
        /* background: #fff url("") no-repeat center; */
        background: #fff url("../../assets/img/verifySuccess.png") no-repeat center;  // 图片根据需要替换
       }
       .drag_bg {
        background-color: #4092ff;
        height: 50px;
         0px;
       }
       .drag_text {
        position: absolute;
        top: 0px;
         6.5rem;
        -moz-user-select: none;
        -webkit-user-select: none;
        user-select: none;
        -o-user-select: none;
        -ms-user-select: none;
       }

    效果如下:

    (未拖动)

    (拖动中)

     

    (验证通过)

    参考链接: https://www.jb51.net/article/146191.htm

  • 相关阅读:
    【贪心】【堆】Gym
    【并查集】Gym
    【拓扑排序】【bitset】Gym
    【递归】【线段树】【堆】AtCoder Regular Contest 080 E
    【二分图】【并查集】XVII Open Cup named after E.V. Pankratiev Stage 14, Grand Prix of Tatarstan, Sunday, April 2, 2017 Problem L. Canonical duel
    【动态规划】【滚动数组】【bitset】XVII Open Cup named after E.V. Pankratiev Stage 14, Grand Prix of Tatarstan, Sunday, April 2, 2017 Problem J. Terminal
    【二分】【字符串哈希】【二分图最大匹配】【最大流】XVII Open Cup named after E.V. Pankratiev Stage 14, Grand Prix of Tatarstan, Sunday, April 2, 2017 Problem I. Minimum Prefix
    【枚举】【最小表示法】XVII Open Cup named after E.V. Pankratiev Stage 14, Grand Prix of Tatarstan, Sunday, April 2, 2017 Problem F. Matrix Game
    【推导】【构造】XVII Open Cup named after E.V. Pankratiev Stage 14, Grand Prix of Tatarstan, Sunday, April 2, 2017 Problem E. Space Tourists
    【推导】【贪心】XVII Open Cup named after E.V. Pankratiev Stage 14, Grand Prix of Tatarstan, Sunday, April 2, 2017 Problem D. Clones and Treasures
  • 原文地址:https://www.cnblogs.com/mfbzr/p/14150138.html
Copyright © 2011-2022 走看看