HTML5技术

HTML5元素拖拽实现示例 - 乌拉圭的野鹤

字号+ 作者:H5之家 来源:博客园 2016-02-25 12:00 我要评论( )

HTML5现在前端圈中,已然成为一个不那么新的技术词汇了,很多公司也把HTML5也当成了硬性的技能要求,但是很多前端恐怕都不了解HTML5的拖拽怎么实现吧。 看了下极客学院的视频,大概的了解了下思路。所以整理备份,便于以后查阅。先上示例: index.html Drag

HTML5现在前端圈中,已然成为一个不那么新的技术词汇了,很多公司也把HTML5也当成了硬性的技能要求,但是很多前端恐怕都不了解HTML5的拖拽怎么实现吧。

看了下极客学院的视频,大概的了解了下思路。所以整理备份,便于以后查阅。先上示例:

index.html

Drag

 

 

app1.js

1 /** 2 * app1.js oBox1, 6 oBox2, 7 oImg1; 8 9 window.onload = function(){ 10 oBox1 = document.getElementById('box1'); 11 oBox2 = document.getElementById('box2'); 12 oImg1 = document.getElementById('img1'); 13 14 // 15 oBox1.ondragover = oBox2.ondragover = function(e){ 16 e.preventDefault(); 17 }; 18 19 // 20 oImg1.ondragstart = function(e){ 21 e.dataTransfer.setData('text', e.target.id); 22 }; 23 24 oBox1.ondrop = dropImg; 25 oBox2.ondrop = dropImg; 26 }; dropImg(e){ 29 e.preventDefault(); 30 var tempImg = document.getElementById(e.dataTransfer.getData('text')); 31 e.target.appendChild(tempImg); 32 }

 

涉及知识点

在拖放的过程中会触发以下事件:
在拖动目标上触发事件 (源元素)
  ondragstart - 用户开始拖动元素时触发
  ondrag - 元素正在拖动时触发
  ondragend - 用户完成元素拖动后触发

释放目标时触发的事件
  ondragenter - 当被鼠标拖动的对象进入其容器范围内时触发此事件
  ondragover - 当某被拖动的对象在另一对象容器范围内拖动时触发此事件
  ondragleave - 当被鼠标拖动的对象离开其容器范围内时触发此事件
  ondrop - 在一个拖动过程中,释放鼠标键时触发此事件

 

event对象(以e代替)

e.target

  W3Cschool上的解释是:返回触发此事件的元素(事件的目标节点),这个target属性只兼容ie9及以上

e.preventDefault()

  取消事件的默认动作。

e.dataTransfer.setData()

  设置被拖数据的数据类型和值。

e.dataTransfer.setData("Text",ev.target.id); //第一个参数为Text(小写的也行)

e.dataTransfer.getData()

  获得被拖的数据。

e.dataTransfer.getData("Text");

 

 

1.本站遵循行业规范,任何转载的稿件都会明确标注作者和来源;2.本站的原创文章,请转载时务必注明文章作者和来源,不尊重原创的行为我们将追究责任;3.作者投稿可能会经我们编辑修改或补充。

相关文章
  • HTML5 进阶系列:拖放 API 实现拖放排序 - _林鑫

    HTML5 进阶系列:拖放 API 实现拖放排序 - _林鑫

    2017-05-02 11:02

  • HTML5 进阶系列:indexedDB 数据库 - _林鑫

    HTML5 进阶系列:indexedDB 数据库 - _林鑫

    2017-04-27 14:02

  • HTML5 高级系列:web Storage - _林鑫

    HTML5 高级系列:web Storage - _林鑫

    2017-04-27 14:01

  • HTML5和CSS3 - 奔跑在起跑线佼佼者

    HTML5和CSS3 - 奔跑在起跑线佼佼者

    2017-04-20 13:00

网友点评