我的编程空间,编程开发者的网络收藏夹
学习永远不晚

html5中如何使用js实现拖拽功能

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

html5中如何使用js实现拖拽功能

这篇文章主要介绍了html5中如何使用js实现拖拽功能,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。

1. HTML5 拖拽

1.1 相关知识

拖拽元素:可以为元素添加 draggable="true"来让元素能够被拖拽。

拖拽元素的事件监听:(应用于拖拽元素)

  • ondragstart当拖拽开始时调用

  • ondragleave 当鼠标离开拖拽元素时调用

  • ondragend 当拖拽结束时调用

  • ondrag 整个拖拽过程都会调用

目标元素:把元素A拖拽到元素B里,那么元素B就是目标元素。页面中任何一个元素都可以成为目标元素。

目标元素的事件监听:(应用于目标元素)

  • ondragenter 当拖拽元素进入时调用

  • ondragover 当拖拽元素停留在目标元素上时,就会连续一直触发(不管拖拽元素此时是移动还是不动的状态)

  • ondrop 当在目标元素上松开鼠标时调用

  • ondragleave 当鼠标离开目标元素时调用

如果想让拖拽元素在目标元素里做点事情,就必须要在 ondragover() 里加event.preventDefault()这一行代码。

1.2 拖拽基础

<!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>            .box {                width: 200px;                height: 200px;                background: green;            }            .box2 {                position: relative;                left: 300px;                top: 50px;                width: 300px;                height: 300px;                background: red;            }        </style>    </head>    <body>        <div class="box" draggable="true"></div>        <div class="box2"></div>        <script>            // HTML5 拖拽            // 应用于拖拽元素            var box = document.querySelector('.box')            box.ondragstart = function () {                console.log('拖拽开始')            }            box.ondragleave = function () {                console.log('鼠标离开元素')            }            box.ondragend = function () {                console.log('拖拽结束')            }            // box.ondrag = function () {            //     console.log('在拖拽');            // }            // 应用于目标元素(想把 box 拖拽进去的地方)            var box2 = document.querySelector('.box2')            box2.ondragenter = function () {                console.log('进来了')            }            box2.ondragleave = function () {                console.log('离开了')            }            // 当拖拽元素在 目标元素上时,连续触发            box2.ondragover = function (e) {                // 如果想让拖拽元素在目标元素里做点事情,就必须要在 ondragover() 里加event.preventDefault()这一行代码。                e.preventDefault()                console.log('over')            }            box2.ondrop = function () {                console.log('松开鼠标了')            }        </script>    </body></html>

1.3 将 A 在 B、C 之间拖拽

<!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>            .box-b {                width: 250px;                height: 250px;                background: green;            }            .cell-a {                float: left;                width: 50px;                height: 50px;                margin: 5px;                text-align: center;                line-height: 50px;                border-radius: 50%;                background: red;            }            .box-c {                width: 200px;                height: 200px;                margin-top: 10px;                background: skyblue;            }        </style>    </head>    <body>        <p>boxB</p>        <div class="box-b">            <div class="cell-a" draggable="true">1</div>            <div class="cell-a" draggable="true">2</div>            <div class="cell-a" draggable="true">3</div>            <div class="cell-a" draggable="true">4</div>            <div class="cell-a" draggable="true">5</div>        </div>        <p>boxC</p>        <div class="box-c"></div>        <script>            var cellA = document.querySelectorAll('.cell-a')            var boxB = document.querySelector('.box-b')            var boxC = document.querySelector('.box-c')            var temp = null            cellA.forEach((cell, index) => {                // 从 boxB 拖拽到 boxC                cell.ondragstart = function () {                    // 保持当前拖拽的元素                    temp = this                }                cell.ondragend = function () {                    temp = null                }                boxC.ondragover = function (e) {                    e.preventDefault()                }                boxC.ondragenter = function () {                    this.appendChild(temp)                }                // 从 boxC 拖拽到 boxB                boxB.ondragover = function (e) {                    e.preventDefault()                }                boxB.ondragenter = function () {                    this.appendChild(temp)                }            })        </script>    </body></html>

效果展示

html5中如何使用js实现拖拽功能

2. 用 js 实现拖拽

2.1 js 简单拖拽

按下鼠标进行简单的拖拽。

<!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>            #box {                position: absolute;                width: 200px;                height: 200px;                background: green;            }        </style>        <script>            window.onload = function () {                var box = document.getElementById('box')                var disX = 0                var disY = 0                box.onmousedown = function (e) {                    var e = e || window.event                    disX = e.clientX - this.offsetLeft                    disY = e.clientY - this.offsetTop                    box.onmousemove = function (e) {                        var e = e || window.event                        box.style.left = e.clientX - disX + 'px'                        box.style.top = e.clientY - disY + 'px'                    }                    box.onmouseup = function (e) {                        console.log('end')                        this.onmousemove = null                    }                    return false                }            }        </script>    </head>    <body>        <div id="box"></div>    </body></html>

效果展示

html5中如何使用js实现拖拽功能

2.2 带效果的拖拽

<!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>            .box {                position: absolute;                width: 200px;                height: 200px;                background: skyblue;            }            .box1 {                position: absolute;                border: 1px dashed black;                opacity: 0.5;            }            .way-box {                position: absolute;                bottom: 30px;                right: 30px;                                -moz-user-select: none;                 -webkit-user-select: none;                 -ms-user-select: none;                 user-select: none;            }        </style>        <script>            window.onload = function () {                ;(function () {                    var box = document.querySelector('.box')                    var disX, disY, temp                    var body = document.querySelector('body')                    var way1 = document.querySelector('#way1')                    var way2 = document.querySelector('#way2')                    box.onmousedown = function (e) {                        var e = e || window.event // 兼容性写法                        disX = e.clientX - this.offsetLeft                        disY = e.clientY - this.offsetTop                        temp = document.createElement('div')                        body.appendChild(temp)                        temp.classList.add('box')                        temp.classList.add('box1')                        // 移动后位置会变,temp 的位置应该与 box 位置重合                        temp.style.left = e.clientX - disX + 'px' // 记得加单位!                        temp.style.top = e.clientY - disY + 'px'                        temp.onmousemove = function (e) {                            var e = e || window.event                            temp.style.left = e.clientX - disX + 'px' // 记得加单位!                            temp.style.top = e.clientY - disY + 'px'                        }                        temp.onmouseup = function (e) {                            console.log('end')                            this.onmousemove = null                            // 1 则默认不发生实际移动                            if (way2.checked) {                                box.style.left = e.clientX - disX + 'px'                                box.style.top = e.clientY - disY + 'px'                            }                            temp.style.display = 'none'                            this.onmouseup = null                        }                    }                })()            }        </script>    </head>    <body>        <div class="box"></div>        <div class="way-box">            <p>请选择拖拽的方式</p>            <input type="radio" id="way1" name="way" checked />            <label for="way1">1</label>            <input type="radio" id="way2" name="way" />            <label for="way2">2</label>        </div>    </body></html>

效果展示

html5中如何使用js实现拖拽功能

感谢你能够认真阅读完这篇文章,希望小编分享的“html5中如何使用js实现拖拽功能”这篇文章对大家有帮助,同时也希望大家多多支持编程网,关注编程网行业资讯频道,更多相关知识等着你来学习!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

html5中如何使用js实现拖拽功能

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

html5中如何使用js实现拖拽功能

这篇文章主要介绍了html5中如何使用js实现拖拽功能,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。1. HTML5 拖拽1.1 相关知识拖拽元素:可以为元素添加 dragg
2023-06-09

html5如何实现拖拽

这篇文章主要介绍了html5如何实现拖拽,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。html5实现拖拽的方法:首先新建一个空的HTML5结构;然后在body元素中放置一个d
2023-06-15

elementUI中el-dialog如何实现拖拽功能

本文小编为大家详细介绍“elementUI中el-dialog如何实现拖拽功能”,内容详细,步骤清晰,细节处理妥当,希望这篇“elementUI中el-dialog如何实现拖拽功能”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来
2023-07-04

HTML5中如何实现拖放功能

这篇文章主要介绍了HTML5中如何实现拖放功能,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。一、什么是拖放拖放就是通过鼠标放在一个物体上,按住鼠标不放就可以把一个物体托动到另
2023-06-09

怎么在HTML5中利用拖拽功能实现拼图游戏

本篇文章为大家展示了怎么在HTML5中利用拖拽功能实现拼图游戏,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。
2023-06-09

vue3怎么使用vuedraggable实现拖拽功能

这篇文章主要介绍了vue3怎么使用vuedraggable实现拖拽功能的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇vue3怎么使用vuedraggable实现拖拽功能文章都会有所收获,下面我们一起来看看吧。1
2023-06-29

如何实现小程序canvas拖拽功能

这篇“如何实现小程序canvas拖拽功能 ”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“如何实现小程序canvas拖拽功能
2023-06-26

Vue实用功能之实现拖拽元素、列表拖拽排序

在日常开发中,特别是管理端,经常会遇到要实现拖拽排序的效果,下面这篇文章主要给大家介绍了关于Vue实用功能之实现拖拽元素、列表拖拽排序的相关资料,需要的朋友可以参考下
2022-11-13

js如何实现模态框拖拽

今天小编给大家分享一下js如何实现模态框拖拽的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。效果展示和需求分析效果展示需求分析
2023-07-02

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录