博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
HTML5原生拖放事件的学习与实践
阅读量:6858 次
发布时间:2019-06-26

本文共 2021 字,大约阅读时间需要 6 分钟。

前言

之前学习了HTML5的拖放事件,开发中也用到了拖拽组件。为了厘清整体的逻辑,专门做了一个小例子。

具体实现的效果也很简单:元素可以在容器中任意拖动,元素被移入容器的时候,还会有相关样式的改变已达到更好的展示效果。

例子基本运用了拖放事件的全部事件,并且尽量简洁的展示了出来。特此记录。

/

拖放事件介绍

由名字可以看出来,拖放事件由2部分组成:拖动和释放。

而拖动又由2部分组成,分别是被拖动元素的相关事件和元素容器的相关事件。

1、被拖动元素的相关事件 :

事件名称 说明
dragstart 在元素开始被拖动时候触发
drag 在元素被拖动时反复触发
dragend 在拖动操作完成时触发

2、容器的相关事件 :

事件名称 说明
dragenter 当被拖动元素进入目的地元素所占据的屏幕空间时触发,一般需要取消浏览器的默认行为
dragover 当被拖动元素在目的地元素内时触发,一般需要取消浏览器的默认行为
dragleave 当被拖动元素没有放下就离开目的地元素时触发

3、释放事件 :

事件名称 说明
drop 当被拖动元素在目的地元素里放下时触发,一般需要取消浏览器的默认行为

效果展示

为了方便说明,先看代码实现的效果。请前往  下载 demo.html 和 demo.js 到本地,然后用Chrome打开html文件,初始效果如下图:

将图中的可拖拽元素,拖放到下面的容器中,这个过程的效果如下所示。箭头表示拖拽方向,方框代表动态改变的容器样式。

最后,松开鼠标,将元素放入到下面的容器中,整个过程完成。

代码实现

首先,先编写html代码。因为元素可以在两个容器之间任意拖动,因此这两个容器都需要监听drapenter、dragover、dragleave、drop这四个事件。

被拖拽元素的 draggable 属性需要指明为 true ,才可以被拖拽。同时为了记录一些信息,需要监听dragstart事件。

    
被拖拽元素
复制代码

为了让拖拽效果更明显,实现效果展示->第二部分的,拖拽元素进入一个新的容器的时候,新容器展示阴影效果。编写阴影效果样式:

复制代码

最后,编写 demo.js 代码。具体逻辑请看代码中的注释信息:

let target = null,  container = null// 寻找拖拽元素的容器类function findParentContainer(node) {  if(!node || node === document) {    return null  }  if(node.classList.contains('container')) {    return node  }  return findParentContainer(node.parentNode)}// 元素开始被拖拽时, 标记元素原生的容器类function onDragStart(event) {  target = event.target  container = findParentContainer(target)}// 元素进入目的容器时, 如果不是原来的容器, 则可以放置// 此时更改样式, 以更好向用户展示function onDragEnter(event) {  event.preventDefault()  if(event.target !== container) {    event.target.classList.add('active')  }}// 元素在目的容器内时触发function onDragOver(event) {  event.preventDefault()}// 元素离开目的容器, 需要移除相关样式function onDragLeave(event) {  event.preventDefault()  event.target.classList.remove('active')}// 元素被放置在目的容器, 添加DOM节点, 移除相关样式function onDrop(event) {  event.preventDefault()  event.target.appendChild(target)  event.target.classList.remove('active')  target = null  container = null}复制代码

参考链接

  • 代码地址:

更多系列文章

《前端知识体系》

  • ......

《设计模式手册》

  • ......

《Webpack4渐进式教程》

  • ......

转载于:https://juejin.im/post/5cbb26caf265da0384128b2f

你可能感兴趣的文章
Linux环境下安装mysql并分配用户权限
查看>>
VR视频创作,想说爱你不容易
查看>>
笨办法学 Python · 续 练习 23:三叉搜索树
查看>>
可穿戴设备不能急于戴上“智能”的高帽子
查看>>
扒一扒政府的专用黑客组织ZooPark
查看>>
Ubuntu下Deb软件包相关安装与卸载
查看>>
互联网转型需要微服务架构
查看>>
Airbus Safran Launchers:选择西门子彻底改革产品生命周期流程
查看>>
文本数据的分分合合
查看>>
无损音乐知识收集2(转)
查看>>
vim 工具(一)
查看>>
MySQL常用命令
查看>>
zabbix snmp监控
查看>>
MySQL单实例重置密码的两种方法
查看>>
一段典型的PHP程序都包含那些内容呢?
查看>>
Windows Phone 7 数据绑定的简单介绍
查看>>
合并下载的Solaris镜像为DVD文件的方法
查看>>
shell编程入门步步高(一、shell简介)
查看>>
一个简单的HQL优化
查看>>
从股价说起 百神大战凸现百度与腾讯阿里差距
查看>>