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

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

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

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

template:

<template><div><div class="movebox" >        <div class="move"></div>        <div class="txt" id="txt">拖动滑块验证</div>        <div class="move moveBefore" v-move></div> </div><div class="movebox" >        <div class="move"></div>        <div class="txt" id="txt">拖动滑块验证</div>        <div class="move moveBefore" v-move></div> </div></div></template>

项目中使用的是scss;

css代码:

<style lang="scss" scoped>.movebox{  position: relative;  background-color: #e8e8e8;  width: 300px;  height: 34px;  line-height: 34px;  text-align: center;  .txt{  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;  }  .move{   background-color: #7ac23c;   height: 34px;   width: 0px;  }   .move{    position: absolute;  top: 0px;  left: 0px;  width: 40px;  height: 34px;  border: 1px solid #ccc;  cursor: move;   }   .moveBefore{   background: #fff url("") no-repeat center;       }   .moveSuccess{    background: #fff url("") no-repeat center;       }  }</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'     //$('.move').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制作软件略卡;

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。

tag:滑块验证自定义指令示例电脑软件

相关内容