JavaScript拖拽API的简单使用

演示效果:

html 复制代码
<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <style>
        .father {
            display: flex;
        }

        #box1,
        #box2 {
            display: flex;
            align-items: center;
            justify-content: center;
            width: 100px;
            height: 100px;
            border: 1px solid #000;
        }

        #box2 {
            margin-left: 100px;
        }
    </style>
</head>

<body>
    <div class="father">
        <div id="box1"></div>
        <div id="box2">
            <!-- 将图片设置为可拖拽状态 -->
            <img id="pic" draggable="true" src="./images/car.png">
        </div>
    </div>

    <script>
        const box1 = document.querySelector('#box1');
        const pic = document.querySelector('#pic');

        // 将鼠标指针悬停在box1元素上,并拖拽其他元素时
        box1.addEventListener('dragover', e => {
            e.preventDefault(); // 阻止默认行为
        })

        // 当拖放操作在目标元素上执行时触发
        box1.addEventListener('drop', e => {
            const id = e.dataTransfer.getData('text/plain'); // 获取拖拽数据
            e.target.appendChild(document.getElementById(id)); // 将拖拽的元素添加到目标元素中
        })

        // 拖放开始时触发
        pic.addEventListener('dragstart', e => {
            console.log('开始拖拽', e);
            e.dataTransfer.setData('text/plain', e.target.id); // 设置拖拽数据
        })

        // 拖放操作结束时触发
        pic.addEventListener('dragend', e => {
            console.log('结束拖拽', e);
        })
    </script>
</body>

</html>
相关推荐
我爱挣钱我也要早睡!43 分钟前
Java 复习笔记
java·开发语言·笔记
Yang-Never2 小时前
Kotlin协程 -> Job.join() 完整流程图与核心源码分析
android·开发语言·kotlin·android studio
牧羊狼的狼2 小时前
React 中的 HOC 和 Hooks
前端·javascript·react.js·hooks·高阶组件·hoc
知识分享小能手3 小时前
React学习教程,从入门到精通, React 属性(Props)语法知识点与案例详解(14)
前端·javascript·vue.js·学习·react.js·vue·react
luckys.one3 小时前
第9篇:Freqtrade量化交易之config.json 基础入门与初始化
javascript·数据库·python·mysql·算法·json·区块链
TomCode先生4 小时前
c#动态树形表达式详解
开发语言·c#
mCell4 小时前
JavaScript 的多线程能力:Worker
前端·javascript·浏览器
高-老师4 小时前
基于R语言的物种气候生态位动态量化与分布特征模拟
开发语言·r语言·物种气候
大翻哥哥5 小时前
Python 2025:量化金融与智能交易的新纪元
开发语言·python·金融
weixin_437830945 小时前
使用冰狐智能辅助实现图形列表自动点击:OCR与HID技术详解
开发语言·javascript·ocr