当前位置: 移动技术网 > IT编程>脚本编程>vue.js > vue 中自定义指令改变data中的值

vue 中自定义指令改变data中的值

2017年12月12日  | 移动技术网IT编程  | 我要评论

法网情丝,开兴网,行尸走肉第五季第九集

通过局部自定义指令实现了一个拖动的指令

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中的值,希望对大家有所帮助

如对本文有疑问,请在下面进行留言讨论,广大热心网友会与你互动!! 点击进行留言回复

相关文章:

验证码:
移动技术网