• vue-cli 自定义指令directive 添加验证滑块


    欢迎加入前端交流群来获取视频资料以及前端学习资料749539640

    ----------------------------------------------------------

                      转载文章请注明出处!               

    ----------------------------------------------------------

    预览地址:https://jsfiddle.net/wangzhichao/dx9yf20w/

    gif截图软件帧数略低。。。。

    vue项目注册登录页面遇到了一个需要滑块的功能,网上看了很多插件发现都不太好用,于是自己写了一个插件供大家参考;

    用的是vue的自定义指令direcive,只需要在需要的组件里放入对应的标签嵌套即可;

    template:

     1   <template>
     2 <div>
     3 <div class="movebox" >
     4                 <div class="movego"></div>
     5                 <div class="txt" id="txt">拖动滑块验证</div>
     6                 <div class="move moveBefore" v-move></div>
     7  </div>
     8 <div class="movebox" >
     9                 <div class="movego"></div>
    10                 <div class="txt" id="txt">拖动滑块验证</div>
    11                 <div class="move moveBefore" v-move></div>
    12  </div>
    13 </div>
    14 </template>

     项目中使用的是scss;

    css代码:

     1 <style lang="scss" scoped>
     2 
     3 
     4 .movebox{
     5     position: relative;
     6     background-color: #e8e8e8;
     7      300px;
     8     height: 34px;
     9     line-height: 34px;
    10     text-align: center;
    11     .txt{
    12     position: absolute;
    13     top: 0px;
    14      300px;
    15     -moz-user-select: none;
    16     -webkit-user-select: none;
    17     user-select: none;
    18     -o-user-select: none;
    19     -ms-user-select: none;
    20     }
    21     .movego{
    22       background-color: #7ac23c;
    23       height: 34px;
    24        0px;
    25     }
    26       .move{
    27         position: absolute;
    28     top: 0px;
    29     left: 0px;
    30      40px;
    31     height: 34px;
    32     border: 1px solid #ccc;
    33     cursor: move;
    34       }
    35       .moveBefore{
    36      background: #fff url("") no-repeat center;
    37 
    38         
    39       }
    40       .moveSuccess{
    41         background: #fff url("") no-repeat center;
    42 
    43         
    44       }
    45     }
    46 </style>

    jquery已经在全局引入,需要jquery全局引入的,可以看我的上一篇博客,里面有jquery的引入;

    script:

    <script>
    
    
    export default {
      components: {
        
      },
      data() {
        return {        
        }
      },
      mounted() {
       //console.log($('选择器'))
      },
      methods: {
            },
      directives: {
        move(el) {
            el.onmousedown = function(e) {
            var X = e.clientX - el.offsetLeft
            document.onmousemove = function(e) {
                var endx = e.clientX - X
            el.className = 'move moveBefore'
            el.style.left = endx + 'px'
           // console.log(el.parentNode.children[0])
            var width = $('.movebox').width() - $('.move').width()
             el.parentNode.children[0].style.width = endx + 'px'
             el.parentNode.children[1].innerHTML = '拖动滑块验证'
            //临界值小于
            if (endx <= 0) {
            el.style.left = 0 + 'px'
             el.parentNode.children[0].style.width = 0 + 'px'
             //$('.movego').width(0)
            }
            //临界值大于
           // console.log(el.style.left)
            if (parseInt(el.style.left) >= width) {
            el.style.left = width + 'px'
             el.parentNode.children[0].style.width = width + 'px'
             el.parentNode.children[1].innerHTML = '验证通过'
            el.className = 'move moveSuccess'
            el.onmousedown = null
            }
            }
        }
        document.onmouseup = function() {
            document.onmousemove = null
        }
        }
      }
    }
    
    </script>

     谢了近20分钟,调试好了,效果还是比较可以的:

    用的gif制作软件略卡;

     

  • 相关阅读:
    Struts2框架详解
    Eclipse利用Axis2插件构建Web Service并测试
    解决JS中各浏览器Date格式不兼容的问题
    Struts2框架下表单数据的流向以及映射关系
    JMS总结
    第一次博客园
    微信OAuth2网页授权
    将List转换成DataTable
    对文件的读写操作
    Excel文件的导出操作
  • 原文地址:https://www.cnblogs.com/wangzhichao/p/7692277.html
Copyright © 2020-2023  润新知