JS拖拽事件

本文介绍了JavaScript中的拖拽事件,包括dataTransfer对象、draggable属性、ondragstart、ondragmove、ondragenter、ondragover、ondrop、ondragend事件。重点讲述了Event.preventDefault()方法用于阻止默认行为,以及Event.effectAllowed属性设置拖拽效果的重要性。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

拖拽事件分为:
  1. - dataTransfer 对象:退拽对象用来传递的媒介,使用一般为Event.dataTransfer。
  2. - draggable 属性:就是标签元素要设置draggable=true,否则不会有效果,例如:<div title="拖拽我" draggable="true">列表1</div>
  3. - ondragstart 事件:当拖拽元素开始被拖拽的时候触发的事件,此事件作用在被拖曳元素上
  4. - ondragmove事件:当拖拽元素在拖拽中触发的事件,此事件作用在被拖曳元素上
  5. - ondragenter 事件:当拖曳元素进入目标元素的时候触发的事件,此事件作用在目标元素上
  6. - ondragover 事件:拖拽元素在目标元素上移动的时候触发的事件,此事件作用在目标元素上
  7. - ondrop 事件:被拖拽的元素在目标元素上同时鼠标放开触发的事件,此事件作用在目标元素上
  8. - ondragend 事件:当拖拽完成后触发的事件,此事件作用在被拖曳元素上
  9. - Event.preventDefault() 方法:阻止默认的些事件方法等执行。在ondragover中一定要执行preventDefault(),否则ondrop事件不会被触发。另外,如果是从其他应用软件或是文件中拖东西进来,尤其是图片的时候,默认的动作是显示这个图 片或是相关信息,并不是真的执行drop。此时需要用用document的ondragover事件把它直接干掉。
  10. - Event.effectAllowed 属性:就是拖拽的效果。
dragstart示例代码

dragstart (event) {
  /* if (!this.zoomStatus) {
    event.preventDefault() // 会阻止drag的后续事件,相当不再执行拖拽
  } */
  event.dataTransfer.setDragImage(this.$refs.empty_drag, 0, 0)
// 记录初始量
  this.dragX = event.pageX
  this.dragY = event.pageY
},

dragmove事件示例

dragmove (event) {
// 计算偏移量
  this.left += event.pageX - this.dragX
  this.top += event.pageY - this.dragY
  this.dragX = event.pageX
  this.dragY = event.pageY
},
注意:监控drag事件时,注意ondragstart、ondragmove、ondragend三个事件的区别以及event的不同,因为这三个事件都会被监控到,可以用event.type来判断


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值