html5-drag和drop拖拽

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>
        ul {
            width: 1000px;
            height: 200px;
            background: palegreen;
        }

        main {
            border: 2px solid #333;
            height: 300px;
            width: 1200px;
        }
    </style>
</head>

<body>

    <ul id="oriDiv" draggable="true">
        <li>111111</li>
        <li>222222</li>
        <li>333333</li>
        <li>444444</li>
        <li>555555</li>
    </ul>

    <main id="main"></main>
    <script>
        oriDiv.ondragstart = function () {
            console.log('drag start')
        }

        main.ondragenter = function () {
            console.log('drag enter')
        }

        main.ondragleave = function () {
            console.log('drag leave')
        }


        main.ondragover = function (e) {
            e.preventDefault()
            console.log('drag over')
        }

        // @WARN:使用drop时注意,需要首先将drop事件的前一个事件dragover的浏览器默认操作禁止,
        // 才可以触发drop事件。 
        main.ondrop = function () {
            console.log('drop ...')
        }

        /**
         * source
         */
        oriDiv.ondragstart = (e) => {
            console.log('clearing data ...')
            e.dataTransfer.cleanData()
            console.log('setting data ...')
            e.dataTransfer.setData('name', JSON.stringify({ name: 'xiaoming' }))
        }

        /**
         * target
         */
        main.ondragover = (e) => {
            e.preventDefault()
        }

        main.ondrop = (e) => {
            console.log('getting data ...')
            data = JSON.parse(e.dataTransfer.getData('name'))
            console.log(data.name)
        }

        /**
         * Example code
         */
        const img = document.querySelectorAll('img')
        const des = document.querySelectorAll('div')

        for (let i = 0; i < des.length; i++) {
            img[i].ondragstart = (e) => {
                e.dataTransfer.setData('id', e.target.id)
            }
            des[i].ondragover = (e) => {
                e.preventDefault()
            }

            des[i].ondrop = (e) => {
                const id = e.dataTransfer.getData('id')
                this.appendChild(document.getElementById(id))
            }
        }
    </script>
</body>

</html>
相关推荐
AI浩4 小时前
【Labelme数据操作】LabelMe标注批量复制工具 - 完整教程
运维·服务器·前端
涔溪4 小时前
CSS 网格布局(Grid Layout)核心概念、基础语法、常用属性、实战示例和进阶技巧全面讲解
前端·css
2401_878454534 小时前
浏览器工作原理
前端·javascript
西陵5 小时前
为什么说 AI 赋能前端开发,已经不是选择题,而是必然趋势?
前端·架构·ai编程
by__csdn6 小时前
Vue3 setup()函数终极攻略:从入门到精通
开发语言·前端·javascript·vue.js·性能优化·typescript·ecmascript
天天扭码6 小时前
前端如何实现RAG?一文带你速通,使用RAG实现长期记忆
前端·node.js·ai编程
Luna-player6 小时前
在前端中,<a> 标签的 href=“javascript:;“ 这个是什么意思
开发语言·前端·javascript
lionliu05197 小时前
js的扩展运算符的理解
前端·javascript·vue.js
小草cys7 小时前
项目7-七彩天气app任务7.4.2“关于”弹窗
开发语言·前端·javascript
奇舞精选7 小时前
GELab-Zero 技术解析:当豆包联手中兴,开源界如何守住端侧 AI 的“最后防线”?
前端·aigc