昨天在做的一个功能时,同时弹出多个框展示多个表格数据。 这些弹出框可以自由拖动。单独的拖动好实现,给元素绑定 mousedowm 事件。 这里就想到了 Vue 里面自定义指令来实现。
昨天在做的一个功能时,同时弹出多个框展示多个表格数据。
这些弹出框可以自由拖动。单独的拖动好实现,给元素绑定 mousedowm 事件。
这里就想到了 Vue 里面自定义指令来实现。
在使用自定义指令之前,先对自定义指令有一定的了解。从以下几个方面着手:
1、自定义指令定义范围
全局注册和组件内注册(注册的范围根据实际业务需求来)
// 注册一个全局指令,可以在任何组件使用
Vue.directive('focus',{
// 当被绑定的元素插入 DOM 时
inserted: function(el){
// 聚焦元素
el.focus()
}
})
// 在组件内注册,只能当前组件使用
directives:{
focus:{
inserted: function(el){
el.focus()
}
}
}
// 使用
<input v-focus>
2、钩子函数
对于一个指令有下面一些钩子函数可以选择:
3、函数参数
指令钩子函数会被传入以下参数:
name:指令名
value:指令绑定的值
oldValue:指令绑定的前一个值
expression:字符串形式的指令表达式
arg:传给指令的参数
modifiers:一个包含修饰符的对象
拖动的实现:给目标 Element 注册 mousedown 事件,在这个事件里面再对 document 的 mousemove 和 mouseup 注册。
代码如下:
directives: {
drag: {
// 拖动标题栏,让父元素改变位置,这里所以选择 inserte的
inserted: (el) => {
const target = el.parentElement
el.onmousedown = (e) => {
const disX = e.pageX - target.offsetLeft
const disY = e.pageY - target.offsetTop
document.onmousemove = (de) => {
target.style.left = de.pageX - disX + 'px'
target.style.top = de.pageY - disY + 'px'
}
document.onmouseup = (de) => {
document.onmousemove = document.onmouseup = null
}
}
}
}
}
在需要的 Element 上面使用 v-drag 即可。
到此这篇关于Vue 自定义指令实现元素拖动的文章就介绍到这了,更多相关Vue 自定义指令元素拖动内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!
--结束END--
本文标题: 关于Vue自定义指令实现元素拖动的详细代码
本文链接: https://lsjlt.com/news/162857.html(转载时请注明来源链接)
有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341
2024-01-12
2023-05-20
2023-05-20
2023-05-20
2023-05-20
2023-05-20
2023-05-20
2023-05-20
2023-05-20
2023-05-20
回答
回答
回答
回答
回答
回答
回答
回答
回答
回答
0