Rumah  >  Artikel  >  hujung hadapan web  >  vue-cli 自定义指令directive 添加验证滑块详解

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

小云云
小云云asal
2018-05-31 10:32:493061semak imbas

vue项目注册登录页面遇到了一个需要滑块的功能,网上看了很多插件发现都不太好用,于是自己写了一个插件供大家参考;本文主要介绍了vue-cli 自定义指令directive 添加验证滑块示例,具有一定的参考价值,感兴趣的小伙伴们可以参考一下,希望能帮助到大家。

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

template:

<template>
<p>
<p class="movebox" >
        <p class="movego"></p>
        <p class="txt" id="txt">拖动滑块验证</p>
        <p class="move moveBefore" v-move></p>
 </p>
<p class="movebox" >
        <p class="movego"></p>
        <p class="txt" id="txt">拖动滑块验证</p>
        <p class="move moveBefore" v-move></p>
 </p>
</p>
</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;
  }
  .movego{
   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($(&#39;选择器&#39;))
 },
 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 = &#39;move moveBefore&#39;
    el.style.left = endx + &#39;px&#39;
    // console.log(el.parentNode.children[0])
    var width = $(&#39;.movebox&#39;).width() - $(&#39;.move&#39;).width()
     el.parentNode.children[0].style.width = endx + &#39;px&#39;
     el.parentNode.children[1].innerHTML = &#39;拖动滑块验证&#39;
    //临界值小于
    if (endx <= 0) {
    el.style.left = 0 + &#39;px&#39;
     el.parentNode.children[0].style.width = 0 + &#39;px&#39;
     //$(&#39;.movego&#39;).width(0)
    }
    //临界值大于
    // console.log(el.style.left)
    if (parseInt(el.style.left) >= width) {
    el.style.left = width + &#39;px&#39;
     el.parentNode.children[0].style.width = width + &#39;px&#39;
     el.parentNode.children[1].innerHTML = &#39;验证通过&#39;
    el.className = &#39;move moveSuccess&#39;
    el.onmousedown = null
    }
    }
  }
  document.onmouseup = function() {
    document.onmousemove = null
  }
  }
 }
}

</script>

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

用的gif制作软件略卡;

相关推荐:

关于Angularjs的自定义指令Directive的具体介绍

AngularJS中directive指令使用之事件绑定与指令交互用法示例

vue指令directive

Atas ialah kandungan terperinci vue-cli 自定义指令directive 添加验证滑块详解. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn