HTML5--拖拽事件与DataTransfer对象
需求分析 -- 生产开发中元素的拖拽是一个相当常见的需求,这就需要用到draggable这个属性以及对应的拖拽相关事件
如果想要拖动某个元素那么首先就需要给其一个draggable属性,并将该属性设置为true
拖放事件
拖放的过程中被拖放的对象称为源对象,拖放过程中间经过的其他对象被称为过程对象,最终到达的目标区域叫做目标对象,拖放事件可以用这几个对象来进行分类,不同的事件会被不同的对象触发
源对象
dragstart : 源对象开始拖放,开始移动事件触发
drag : 源对象拖放过程中,移动被拖拽对象触发
dragend : 源对象拖放结束,整个拖放操作结束时触发
过程对象
dragenter : 源对象进入过程对象范围内,被拖拽对象进入过程时被触发
dragover : 源对象在过程对象范围内移动,被拖拽对象在过程对象内移动时触发
dragleave : 源对象离开过程对象的范围,被拖拽对象离开目标对象时触发
目标对象
drop:源对象拖放到目标对象中,目标对象完全接受被拖拽对象时触发,可理解为在目标对象内松手时触发
dataTransfer对象 -- 在所有的拖放事件中都提供了一个数据传输对象dataTransfer,主要作用于源对象和目标对象之间的传递数据
setData(format,data)
设置拖拽事件中要传递的数据,format的参数为数据类型
该方法向dataTransfer中对象中存入数据,接受两个参数,第一个表示要存入的数据类型,共有四种
text/plain
text/html
text/xml
text/uri-list
第二个参数为要存入的数据,例如event.dataTransfer.setData('text/plain','hellow draggable')
getData(format)
获得拖拽事件中传递的数据,format参数为数据结构
该方法从dataTransfer对象中存储的数据,参数为在setData方法中指定的数据类型,例如:event.dataTransfer.getData('text/plain')
clearData()
该方法清空dataTransfer对象中存储的数据,参数可选,为数据类型。若为空,则清空所有数据
例子
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 | <!DOCTYPE HTML> <html> <head> <style type= "text/css" > #box1, #box2, #box3{ width: 200px; height: 300px; border-radius: 10px; border: 1px solid #333; float: left; margin-left: 20px; } #item1,#item2,#item3,#item4 { width: 90%; margin: 0 auto; border-radius: 10px; height: 50px; border: 1px solid #333; margin-top: 10px; text-align: center; line-height: 50px; } </style> </head> <body> <div id= "box1" ondragover= "allowDropIn(event)" ondrop= "drop(event)" > <div id= "item1" draggable= "true" ondragstart= "drag(event)" >方块一</div> <div id= "item2" draggable= "true" ondragstart= "drag(event)" >方块二</div> <div id= "item3" draggable= "true" ondragstart= "drag(event)" >方块三</div> </div> <div id= "box2" ondragover= "allowDropIn(event)" ondrop= "drop(event)" > <div id= "item4" draggable= "true" ondragstart= "drag(event)" >方块四</div> </div> <div id= "box3" ondragover= "allowDropIn(event)" ondrop= "drop(event)" > </div> </body> <script type= "text/javascript" > function allowDropIn(ev) { ev.preventDefault(); } function drag(ev) { ev.dataTransfer.setData( "Text" , ev.target.id); } function drop(ev) { let pattern1 = /^box/ var data = ev.dataTransfer.getData( "Text" ); console.log( 'ev' ,ev.target,ev.dataTransfer) if (pattern1.test(ev.target.id)) { ev.target.appendChild(document.getElementById(data)); ev.preventDefault(); } } </script> </html> |
效果
三个盒子可以任意拖拽将其中的子项进行交换
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 全程不用写代码,我用AI程序员写了一个飞机大战
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· 记一次.NET内存居高不下排查解决与启示
· DeepSeek 开源周回顾「GitHub 热点速览」
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了