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>
相关推荐
XMYX-01 分钟前
12 - Go Slice:底层原理、扩容机制与常见坑位
开发语言·golang
codeejun2 分钟前
每日一Go-50、Go微服务--配置中心
开发语言·微服务·golang
泽02024 分钟前
LLMChat ----- 通过C++语言调用大语言模型所实现的聊天系统
开发语言·c++·语言模型
蒸汽求职6 分钟前
告别静态文档:利用 Notion 搭建“交互式”简历的降维展示策略
开发语言·缓存·面试·职场和发展·金融·notion
steem_ding8 分钟前
C++ 回调函数详解
开发语言·c++·算法
会编程的土豆9 分钟前
字符串知识(LCS,LIS)区分总结归纳
开发语言·数据结构·c++·算法
五仁火烧10 分钟前
前端不传文件,也能用 multipart/form-data
前端·javascript·vue.js·node.js
FuckPatience10 分钟前
未能加载项目文件。名称不能以“<”字符(十六进制值 0x3C)开头
开发语言
五仁火烧14 分钟前
前端最常用的两种请求数据格式application/json 和 multipart/form-data 完全解析
前端·javascript·vue.js·json
书到用时方恨少!15 分钟前
Python 面向对象编程:从“过程清单”到“智能积木”的思维革命
开发语言·python·面向对象