vue 中自定义指令改变data中的值
程序员文章站
2022-03-21 15:02:38
通过局部自定义指令实现了一个拖动的指令
html:
通过局部自定义指令实现了一个拖动的指令
html:
<div style="position:absolute;width:100px;height:100px;border:1px solid red" v-drag="{set:set}"></div>
script:
methods:{ set(x,y){ this.data.x=x; this.data.y=y; } }, directives:{ // 拖动的自定义指令 drag(el,binding){ //el为拖动的元素 var odiv =el; odiv.onmousedown = function(e){ e.preventdefault(); e.stoppropagation(); var disx = e.offsetx; var disy = e.offsety; document.onmousemove = function(e){ e.preventdefault(); e.stoppropagation(); var x=e.pagex-disx; var y=e.pagey-disy odiv.style.left=x odiv.style.top=y // 通过传参的形式,将methods中的函数传进来,以此来改变data中的值 binding.value.set(x,y) }; document.onmouseup = function(){ document.onmousemove=null; document.onmouseup=null; }; }; } },
以上所述是小编给大家介绍的vue 中自定义指令改变data中的值,希望对大家有所帮助