9. 元素拖拽

元素拖拽

API 介绍

1. 拖放过程

整个拖放过程中,存在两个关键元素:拖拽元素、放置元素 拖拽元素:被拖拽的元素

  • drag:元素被拖拽时触发,从开始拖拽到拖拽结束前整个过程会一直持续的触发
  • dragstart:元素被拖拽开始时触发
  • drop:拖拽元素被放置到放置元素内时触发,如果没有在放置元素内松手,则不会触发

放置元素:

  • dragenter:有拖拽元素进入时触发
  • dragover:有拖拽元素在该元素上时触发,在离开前会持续触发
  • dragleave:拖拽元素离开时触发
  • dragend:拖拽元素放置时触发

在这里插入图片描述

2. 可拖拽元素

在 HTML 中,文本、图片和链接是默认可以拖放的元素。其他元素都是默认不可拖动的,如果需要让其他非默认可拖动的 HTML 元素变得可拖动,比如<div><span>等,你需要明确地为这些元素设置 draggable="true" 属性。这样,这些元素就能够接受拖放操作了。

3. 放置元素

所有 HTML 元素在默认情况下都不接受拖拽元素的放置,除非通过特定的事件处理来允许。

要使一个 HTML 元素能够接受被拖动的元素,需要对这个元素进行一些特定的设置和事件绑定:

  • dragover 事件:当被拖动的元素在另一个元素上方移动时,会触发 dragover 事件。为了接受拖放,必须在 dragover 事件处理器中调用 event.preventDefault()方法,这会阻止浏览器的默认行为,也就是不接受任何被拖放的元素。

4. DataTransfer

DataTransfer 对象用于保存拖动并放下(drag and drop)过程中的数据。它可以保存一项或多项数据,这些数据项可以是一种或者多种数据类型

  • dropEffect:获取当前选定的拖放操作类型,或设置为一个新的类型。值必须为 none、copy、link、move
  • effectAllowed:提供所有可用的操作类型。值必须为 none、copy、copyLink、copyMove、link、copyMove、move、all、uninitialized
  • files:包含数据传输中的所有本地文件列表
  • items(只读):提供一个包含所有拖动数据列表的 DataTransferItemList 对象
  • types(只读):一个提供 dragstart 事件中设置的格式的 strings 数组
<template><div id="drag-content" ref="contentRef" @dragstart="dragstart" @dragover="dragover" @dragenter="dragenter" @drop="drop" @dragend="dragend"><div class="left" data-drop="move"><div data-effect="copy" draggable="true" style="background: rgb(26, 231, 156)">语文</div><div data-effect="copy" draggable="true" style="background: rgb(107, 219, 15)">数学</div><div data-effect="copy" draggable="true" style="background: rgb(208, 133, 13)">英语</div><div data-effect="copy" draggable="true" style="background: rgb(30, 98, 246)">物理</div><div data-effect="copy" draggable="true" style="background: rgb(210, 40, 113)">化学</div><div data-effect="copy" draggable="true" style="background: rgb(210, 224, 26)">生物</div></div><div class="right"><table><thead><tr><td>星期一</td><td>星期二</td><td>星期三</td><td>星期四</td><td>星期五</td></tr></thead><tbody><tr><td data-drop="copy"></td><td data-drop="copy"></td><td data-drop="copy"></td><td data-drop="copy"></td><td data-drop="copy"></td></tr><tr><td data-drop="copy"></td><td data-drop="copy"></td><td data-drop="copy"></td><td data-drop="copy"></td><td data-drop="copy"></td></tr><tr><td data-drop="copy"></td><td data-drop="copy"></td><td data-drop="copy"></td><td data-drop="copy"></td><td data-drop="copy"></td></tr><tr><td data-drop="copy"></td><td data-drop="copy"></td><td data-drop="copy"></td><td data-drop="copy"></td><td data-drop="copy"></td></tr></tbody></table></div></div>
</template><script setup lang="ts">
import { reactive, ref } from 'vue'
const contentRef = ref(null)const state = reactive({source: null as HTMLElement | null,dropNode: null
})const dragover = (e) => {// 接受拖放元素e.preventDefault()
}const dragstart = (e) => {if (e.target.dataset.effect === 'move') {e.dataTransfer.effectAllowed = 'move'}state.source = e.target// 设置拖拽元素的样式e.target.style.opacity = '0.2'
}const dragenter = (e) => {const dropNode = getDropNode(e.target)// 判断放置元素是否可以接收拖拽元素,当 data-effect 和 data-drop 的值相等时,说明可以if (dropNode && dropNode.dataset.drop === (state.source as HTMLElement).dataset.effect) {// 给放置元素添加样式dropNode.classList.add('hover-background')}
}// 获取最近的可接受拖拽元素的父节点
const getDropNode = (node) => {while (node) {//  判断元素是否设置了data-drop属性,如果设置了,说明此元素是一个放置元素if (node.dataset && node.dataset.drop) {return node}node = node.parentNode}return node
}const clearHoverClass = () => {document.querySelectorAll('.hover-background').forEach((ele) => ele.classList.remove('hover-background'))
}const drop = (e) => {// 清除hover时的样式clearHoverClass()// 获取最近的放置节点const dropNode = getDropNode(e.target)if (dropNode && dropNode.dataset.drop === (state.source as HTMLElement).dataset.effect) {// 如果是新增课程if (dropNode.dataset.drop === 'copy') {dropNode.innerHTML = ''const cloned = (state.source as HTMLElement).cloneNode(true)if (cloned instanceof HTMLElement) {cloned.dataset.effect = 'move'cloned.style.opacity = '1'}dropNode.appendChild(cloned)// 移除课程} else {;(state.source as HTMLElement).remove()}}
}const dragend = (e) => {e.target.style.opacity = '1'
}
</script><style scoped lang="scss">
#drag-content {display: flex;.left {width: 80px;line-height: 32px;margin-right: 20px;div {padding: 10px;margin-bottom: 10px;text-align: center;color: white;}}.right {flex: 1;table {margin: 10px;td {width: 120px;height: 65px;div {padding: 10px;text-align: center;color: white;}}}}.hover-background {background-color: aqua;}
}
</style>

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.pswp.cn/news/912076.shtml
繁体地址,请注明出处:http://hk.pswp.cn/news/912076.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

用来提升同花顺软件进程优先级的C#程序

为了提高炒股软件同花顺的运行速度&#xff0c;消除卡顿&#xff0c;编写一个C#程序&#xff0c;来设置同花顺进程的优先级。 using System; using System.Diagnostics; using System.Security.Principal;namespace ProcessPrioritySetter {class Program{static void Main(st…

linux初阶---一些指令

一.快速认识6-8个简单指令 1.pwd pwd指令是用来查看用户当前所处在的目录&#xff08;目录的概念在理解上可以等效为文件夹&#xff09;。 &#xff08;1&#xff09;在windows系统中我们通过文件路径表示唯一的文件&#xff0c;在linux中也是一样的&#xff0c;所以pwd是一个很…

全国产传感器外壳的综合分析:材料选择、考量因素与尺寸精度影响

全国产传感器作为现代工业、科研、生活等领域的 “感知触角”&#xff0c;其外壳的性能与质量直接关乎设备的稳定性、可靠性与使用寿命。从材料选型、关键考量因素到尺寸精度的影响&#xff0c;每个环节都需精细把控。 一、全国产传感器外壳材料的多元选择 全国产传感器外壳材…

本地缓存Caffeine详解(含与Spring Cache集成)

目录 一、介绍 二、Caffeine核心原理与架构设计 2.1 存储引擎与数据结构 2.2 缓存淘汰策略 2.3 并发控制机制 三、入门案例 3.1 引入依赖 3.2 测试接口 3.3 小结 四、Caffeine常用方法详解 4.1 getIfPresent 4.2 get 4.3 put 4.4 putAll 4.5 invalidate 4.6 inv…

论特定领域软件架构

20250413-作 题目 特定领域软件架构DSSA&#xff08;Domain Specific Software Architecture&#xff09;就是在一个特定应用领域中为一组应用提供组织结构参考的标准软件体系结构。对DSSA 研究的角度、关心的问题不同导致了对DSSA 的不同定义。DSSA 的必备特征如下。 一…

iOS 远程调试与离线排查实战:构建非现场问题复现机制

iOS开发者都知道&#xff0c;调试最怕两个字&#xff1a;“偶发”。用户说App闪退了&#xff0c;你点了十遍也没问题&#xff1b;测试说功能卡顿了&#xff0c;你抓日志时它又顺滑如新。最麻烦的是&#xff0c;这种“现场问题”往往在你连接不到用户设备时发生。 面对这种情况…

SpringBoot -- 整合 Swagger3

8.SpringBoot3 整合 Swagger3 由于目前主流的开发模式是前后端分离开发。所以前后端的交互需要通过一个 API&#xff08;开发接口&#xff09; 来规范。而这个接口的开发是由后端程序员编写的。“网站式 API 文档” 1.导入依赖 <!-- 引入swagger3(springdoc)的依赖--> …

A Machine Learning Approach for Non-blind Image Deconvolution论文阅读

A Machine Learning Approach for Non-blind Image Deconvolution 1. 研究目标与实际意义2. 创新方法与模型设计2.1 核心思路2.2 正则化反演:理论与公式2.2.1 退化模型2.2.2 正则化目标函数2.2.3 傅里叶域闭式解2.3 MLP去伪影:架构与训练2.3.1 MLP架构设计2.3.2 训练流程2.3.…

微信小程序<rich-text>支持里面图片点击放大

使用<rich-text>渲染类似下面的html代码&#xff1a; <div stylecolor: red>宠物友好<br/>xxx提供宠物友好服务&#xff0c;具体请见下图<br/></div> <img srchttps://xxx.com/xxx1.png width100%/> <img srchttps://xxx.com/xxx2.png…

BVH 文件是一种用于记录 3D 动画数据的文件格式,常用于 3D 建模和动画制作。以下是对这个 BVH 文件的逐行解读

BVH 文件是一种用于记录 3D 动画数据的文件格式&#xff0c;常用于 3D 建模和动画制作。以下是对这个 BVH 文件的逐行解读&#xff1a; HIERARCHY ROOT Hips { OFFSET 0 0 0 CHANNELS 6 Xposition Yposition Zposition Zrotation Xrotation Yrotation JOINT LeftUpLeg { OFFSE…

C语言开发:Onvif(一)

根据ONVIF官网 的介绍&#xff1a; ONVIF是一个开放的安防行业组织&#xff0c;致力于为安防行业提供和促进标准化开放接口&#xff0c;以实现IP网络安防产品和服务的有效互操作性。 在具体实现上&#xff0c;ONVIF使用了Web Service的方式&#xff0c;设备通过WSDL定义的接口…

中科米堆三维扫描仪耳机3D扫描尺寸测量数字化建模

当下&#xff0c;耳机已从单纯的音频输出设备进化为集娱乐、健康、办公于一体的智能穿戴终端。相关数据显示&#xff0c;2025年全球智能个人音频设备出货量突破4.55亿台&#xff0c;中国以22%的增速领跑全球&#xff0c;其中开放式耳机&#xff08;OWS&#xff09;出货量占比达…

学习接口自动化框架pytest有哪些好处?

学习 pytest 作为接口自动化测试框架&#xff0c;具有以下显著优势&#xff0c;能大幅提升测试效率和质量&#xff1a; Pytest自动化测试教程&#xff0c;自动化必备之Pytest测试框架训练营&#xff0c;只需一小时速成&#xff0c;学会直接上手实操&#xff01; 1. 代码简洁&…

LinuxBridge的作用与发展历程:从基础桥接到云原生网络基石

LinuxBridge作为Linux网络虚拟化的核心组件&#xff0c;已悄然支撑互联网基础设施20余年。它不仅是虚拟机网络连接的桥梁&#xff0c;更是容器网络、云原生架构的隐形支柱。 一、LinuxBridge的核心作用剖析 1. 二层网络虚拟化的实现者 本质功能&#xff1a;模拟物理交换机行为…

探讨 SYSCFG 时钟对 ADC 采样的影响

探讨 SYSCFG 时钟对 ADC 采样的影响 在嵌入式系统开发中&#xff0c;对于 GD32F4 系列微控制器&#xff0c;理解 SYSCFG 时钟与 ADC 采样之间的关系至关重要。 以下是详细分析&#xff1a; 一、SYSCFG 时钟对 ADC 采样过程的基础性作用 1. 提供采样时钟信号 ADC 采样需要时钟…

Spring Boot 项目实训 - 图书信息网站

文章目录 1. 实训目的2. 系统设计3. 运行演示4. 实现步骤4.1 创建数据库与表4.2 创建Spring Boot项目4.3 创建实体类4.4 创建映射器接口4.5 编写应用配置文件4.6 测试映射器接口4.7 创建服务类4.8 创建控制器4.9 准备静态资源4.10 创建模板页面4.11 测试整个项目 5. 实训总结 1…

GPU 性能可变性分析框架

大家读完觉得有帮助记得关注和点赞&#xff01;&#xff01;&#xff01; 抽象。 分析来自 GPU 分析器的大规模性能日志通常需要数 TB 的内存和数小时的运行时间&#xff0c;即使是基本摘要也是如此。这些限制会阻止及时洞察&#xff0c;并阻碍将性能分析集成到自动化工作流程中…

Redis主从复制原理

一、Redis主从复制概述 Redis主从复制&#xff08;Master-Slave Replication&#xff09;是Redis实现高可用性和读写分离的基础架构。通过主从复制&#xff0c;数据可以从一个Redis服务器&#xff08;主节点&#xff09;复制到一个或多个Redis服务器&#xff08;从节点&#x…

将ONNX模型转换为(OPENMV可用的格式)TensorFlow Lite格式

将ONNX模型转换为TensorFlow Lite格式 在深度学习模型部署过程中&#xff0c;我们常常需要将模型从一种格式转换为另一种格式&#xff0c;以适应不同的硬件平台和应用场景。本文将详细介绍如何将ONNX格式的模型转换为TensorFlow Lite格式&#xff0c;以便在移动设备或嵌入式设…

EXILIUM×亚矩云手机:重构Web3虚拟生存法则,开启多端跨链元宇宙自由征途

在链游与元宇宙赛道竞争加剧的当下&#xff0c;EXILIUM凭借其去中心化开放世界、链上资产确权与玩家自治经济系统&#xff0c;成为Web3原住民逃离“中心化牢笼”的首选之地。然而&#xff0c;其多链交互门槛高、跨设备身份管理复杂、链上安全风险频发等问题&#xff0c;让普通玩…