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

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

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

template:

<template>

<div>

<div class="movebox" >

<div class="movego"></div>

<div class="txt" id="txt">拖动滑块验证</div>

<div class="move moveBefore" v-move></div>

</div>

<div class="movebox" >

<div class="movego"></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;

}

.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($('选择器'))

},

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制作软件略卡;

以上是 vue-cli 自定义指令directive 添加验证滑块示例 的全部内容, 来源链接: utcz.com/z/326656.html

回到顶部