0

0

如何用javascript实现拖放功能_怎样处理相关事件和数据传递【教程】

幻影之瞳

幻影之瞳

发布时间:2026-01-21 18:40:21

|

867人浏览过

|

来源于php中文网

原创

drop事件不触发是因为目标元素未监听dragover并调用e.preventdefault(),这是浏览器启用投放许可的唯一前提;仅监听drop而忽略dragover会导致静默失败。

如何用javascript实现拖放功能_怎样处理相关事件和数据传递【教程】

拖放功能在 JavaScript 中不是靠单个 API 实现的,而是由 dragstartdragoverdrop 等一整套事件协同完成;不阻止默认行为,drop 事件根本不会触发。

为什么 drop 事件不触发?

浏览器drop 有严格前提:目标元素必须监听 dragover 并调用 e.preventDefault()。否则,即使绑了 drop,它也永远不会执行。

  • dragover 是唯一能“开启投放许可”的事件,缺它或漏掉 preventDefault,整个拖放链就断了
  • 只监听 drop 不监听 dragover,控制台不会报错,但行为静默失败
  • 若目标是 <div> 等非可编辑元素,默认禁止投放,必须显式拦截 <code>dragover

    如何在 dragstart 中传数据?

    dataTransfer 是唯一合法的数据载体,但它只支持字符串类型,且 MIME 类型会影响后续读取方式。

    • e.dataTransfer.setData('text/plain', 'item-123') 写入最通用,兼容所有目标
    • 写入自定义类型如 'application/json' 后,在 drop 中需用 e.dataTransfer.getData('application/json') 精确匹配才能读出
    • 不要试图塞对象或数组进去——setData 会自动转成字符串,JSON 序列化得手动做:e.dataTransfer.setData('text/plain', JSON.stringify({id: 1, type: 'card'}))
    • 浏览器可能忽略未声明的 MIME 类型,稳妥起见优先用 'text/plain''text/uri-list'

    怎样让拖拽视觉反馈更自然?

    仅靠事件不够,需配合 CSS 和 dataTransfer.effectAllowed / dropEffect 控制光标和行为语义。

    Q.AI视频生成工具
    Q.AI视频生成工具

    支持一分钟生成专业级短视频,多种生成方式,AI视频脚本,在线云编辑,画面自由替换,热门配音媲美真人音色,更多强大功能尽在QAI

    下载

    立即学习Java免费学习笔记(深入)”;

    • dragstart 设置 e.dataTransfer.effectAllowed = 'move'(可选值:'copy'、'link'、'move'、'all')
    • dragover 中根据业务逻辑设 e.dataTransfer.dropEffect = 'move',否则光标可能显示为禁止符号
    • :active[draggable="true"]::after 做拖拽中样式不靠谱——应监听 dragstart 添加类,dragend 清除
    • Firefox 对 dataTransfer.setDragImage() 支持最完整,Chrome/Safari 需传入真实 DOM 元素(不能是伪元素),且尺寸建议 ≤ 128×128px

    drop 里怎么安全读取并处理数据?

    别假设 getData() 一定返回东西——用户可能从外部拖入文件、链接或纯文本,来源不可控。

    • 先检查 e.dataTransfer.types 数组,判断有哪些可用类型,再决定用哪个 key 调 getData()
    • 对文件拖放,要用 e.dataTransfer.filesFileList),不是 getData();对 URL,优先试 getData('text/uri-list')
    • 从网页内拖拽时,getData('text/plain') 最可能有值;但若源端没调 setData,这里就是空字符串
    • 避免在 drop 中直接操作 e.target 的子节点结构——它可能是文字节点或不可变元素,应明确操作预期容器(如父级 ul

    真正麻烦的从来不是绑几个事件,而是应对跨源拖拽、移动端兼容、焦点管理、键盘辅助(如按 Space 触发拖拽)这些边界情况;dataTransfer 的类型匹配和 preventDefault 的时机,稍错一点,整个流程就卡死无声。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
json数据格式
json数据格式

JSON是一种轻量级的数据交换格式。本专题为大家带来json数据格式相关文章,帮助大家解决问题。

455

2023.08.07

json是什么
json是什么

JSON是一种轻量级的数据交换格式,具有简洁、易读、跨平台和语言的特点,JSON数据是通过键值对的方式进行组织,其中键是字符串,值可以是字符串、数值、布尔值、数组、对象或者null,在Web开发、数据交换和配置文件等方面得到广泛应用。本专题为大家提供json相关的文章、下载、课程内容,供大家免费下载体验。

546

2023.08.23

jquery怎么操作json
jquery怎么操作json

操作的方法有:1、“$.parseJSON(jsonString)”2、“$.getJSON(url, data, success)”;3、“$.each(obj, callback)”;4、“$.ajax()”。更多jquery怎么操作json的详细内容,可以访问本专题下面的文章。

334

2023.10.13

go语言处理json数据方法
go语言处理json数据方法

本专题整合了go语言中处理json数据方法,阅读专题下面的文章了解更多详细内容。

82

2025.09.10

chrome什么意思
chrome什么意思

chrome是浏览器的意思,由Google开发的网络浏览器,它在2008年首次发布,并迅速成为全球最受欢迎的浏览器之一。本专题为大家提供chrome相关的文章、下载、课程内容,供大家免费下载体验。

1057

2023.08.11

chrome无法加载插件怎么办
chrome无法加载插件怎么办

chrome无法加载插件可以通过检查插件是否已正确安装、禁用和启用插件、清除插件缓存、更新浏览器和插件、检查网络连接和尝试在隐身模式下加载插件方法解决。更多关于chrome相关问题,详情请看本专题下面的文章。php中文网欢迎大家前来学习。

837

2023.11.06

js 字符串转数组
js 字符串转数组

js字符串转数组的方法:1、使用“split()”方法;2、使用“Array.from()”方法;3、使用for循环遍历;4、使用“Array.split()”方法。本专题为大家提供js字符串转数组的相关的文章、下载、课程内容,供大家免费下载体验。

760

2023.08.03

js截取字符串的方法
js截取字符串的方法

js截取字符串的方法有substring()方法、substr()方法、slice()方法、split()方法和slice()方法。本专题为大家提供字符串相关的文章、下载、课程内容,供大家免费下载体验。

221

2023.09.04

C# ASP.NET Core微服务架构与API网关实践
C# ASP.NET Core微服务架构与API网关实践

本专题围绕 C# 在现代后端架构中的微服务实践展开,系统讲解基于 ASP.NET Core 构建可扩展服务体系的核心方法。内容涵盖服务拆分策略、RESTful API 设计、服务间通信、API 网关统一入口管理以及服务治理机制。通过真实项目案例,帮助开发者掌握构建高可用微服务系统的关键技术,提高系统的可扩展性与维护效率。

3

2026.03.11

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Sass 教程
Sass 教程

共14课时 | 0.9万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 3.6万人学习

CSS教程
CSS教程

共754课时 | 42.1万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号