js实现div(javascript拖曳互换div的位置实现示例)
类别:编程学习 浏览量:1164
时间:2021-10-19 06:22:39 js实现div
javascript拖曳互换div的位置实现示例1 实现原理利用dom元素的dragstart/ondragover/ondrop事件完成,在拖曳开始的时候获取到拖曳元素,然后允许拖动,最后鼠标抬起后放到新的位置;这里用到了event.preventDefault()方法,很多人可能比较疑惑,这里简单介绍一下
event.preventDefault() :该方法是让浏览器不要执行与事件关联的默认动作
我们在dragover事件中使用,因为dragover关联的默认动作是阻止将数据或者元素放置到其他元素中;所以需要通过event.preventDefault()禁止该默认事件,这样就可以允许拖动元素到新的位置了
<!-- li拖曳调换顺序 适用gis中切换图层顺序--> <!DOCTYPE html> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> <title></title> <style type="text/css"> body{ display: flex; padding: 100px; flex-direction: column; } li{ width: 100px; height: 100px; text-align: center; } </style> </head> <body> <li style="background-color: red;width:200px;height:200px;" draggable="true">红色</li> <li style="background-color: green;width:100px" draggable="true">绿色</li> <li style="background-color: blue;" draggable="true">蓝色</li> </body> <script type="text/javascript"> let li =document.getElementsByTagName("li"); let container=null; // 遍历给每一个li绑定 dragstart dragover以及drop事件 for(let i=0;i<li.length;i++){ li[i].ondragstart=function(){ container=this } li[i].ondragover=function(){ event.preventDefault(); } li[i].ondrop=function(){ debugger; if(container!=null&&container!=this){ // 具体思路跟变量值互换一样 let temp=document.createElement("li"); document.body.replaceChild(temp,this); //用新建的li占据目的位置 document.body.replaceChild(this,container);// 目的li放置在起始位置 document.body.replaceChild(container,temp) // 起始li放置在目的位置 debugger; console.log('执行业务逻辑') } } } </script> </html>
到此这篇关于javascript拖曳互换li的位置实现示例的文章就介绍到这了,更多相关javascript拖曳互换li内容请搜索开心学习网以前的文章或继续浏览下面的相关文章希望大家以后多多支持开心学习网!
您可能感兴趣
- javascript 经典算法(JavaScript实现的七种排序算法总结推荐!)
- javascript五大继承方式(原生Javascript实现继承方式及其优缺点详解)
- js搜索功能的实现(前端JavaScript实现本地模糊搜索功能的方法实例)
- qt和js相互调用(QT与javascript交互数据的实现)
- javascript写计算器教程(基于JavaScript实现简易计算器)
- jquery五子棋javascript(原生JavaScript实现简单五子棋游戏)
- javascript如何转换int型(浅谈JavaScript中的parseInt的妙用)
- javascript登录转注册界面(JavaScript实现登录窗体)
- canvas实现字体粒子爆炸特效(javascript canvas实现雨滴效果)
- javascript如何操作文档元素(JavaScript操作元素实例大全)
- JavaScript将具有父子关系的数据转化成树形结构,供tree控件使用
- javascript编程中的promise(JavaScript如何利用Promise控制并发请求个数)
- js三级联动说明(基于JavaScript实现省市联动效果)
- javascript弹出菜单(Javascript实现简易导航栏)
- html注册表单验证代码(JavaScript+html实现前端页面随机二维码验证)
- 在vs中设置Javascript的智能提示
- 今天是什么日子(今天是什么日子有什么特殊意义吗)
- 这里输入关键词(怎么输入关键词搜索)
- 34岁的舒畅,就这样走到了末路,不知会不会后悔15年前的草率决定(就这样走到了末路)
- 不走心的古装造型 舒畅 毁容式 出演,萧蔷雷出新高度(不走心的古装造型)
- 嘉南传 第22集(嘉南传第22集)
- 哪版孙悟空最萌 黄渤躺萌了(哪版孙悟空最萌)
热门推荐
- docker修改镜像配置文件(Docker配置本地镜像与容器的存储位置)
- 超简单使用Python换脸实例(超简单使用Python换脸实例)
- packagejson怎么使用(最全的package.json解析)
- 在html代码如何添加php代码(php生成HTML文件的类方法)
- 什么是mongodb 固定集合
- 搭建lnmp的实验心得(Docke容器分离部署LNMP的实现)
- pythonexcel报表实例(对python生成业务报表的实例详解)
- docker compose的常用命令(安装docker和docker-compose实例详解)
- php联合注入列表总结(php中的依赖注入实例详解)
- python多线程实现(python多线程并发让两个LED同时亮的方法)
排行榜
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9