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中call、apply、bind实现原理详解(JavaScript中call、apply、bind实现原理详解)
- jquery留言板代码(JavaScript实现留言板添加删除留言)
- 用javascript设计五子棋(JavaScript实现网页版五子棋游戏)
- html基础知识javascript(JavaScript+html实现前端页面滑动验证)
- javascript的执行原理(一文读懂JavaScript 中的延迟加载属性模式)
- Javascript中apply、call、bind
- js数字时钟编程(JavaScript实现动态数字时钟)
- js使用canvas(JavaScript canvas实现七彩时钟效果)
- javascript写游戏脚本(原生JS实现飞机大战小游戏)
- JavaScriptSerializer对Json对象的序列化和反序列化
- 用javascript解析json(JavaScript JSON.stringify的使用总结)
- JavaScript实现网页版贪吃蛇游戏(JavaScript实现网页版贪吃蛇游戏)
- javascript登录转注册界面(JavaScript实现登录窗体)
- javascript怎么生成html控件(JavaScript+html实现前端页面滑动验证2)
- javascript中需要注意的几个细节
- javascript 开发网站(帮你提高开发效率的JavaScript20个技巧)
- 虐待儿童是发泄支配欲的愚蠢行为(虐待儿童是发泄支配欲的愚蠢行为)
- 你或许不知道你隐藏的支配欲望(你或许不知道你隐藏的支配欲望)
- 把宽体丰田86卖了,换成7.5代高尔夫GTI玩起姿态与性能并存的改装(把宽体丰田86卖了)
- 大众推出了第五代高尔夫GT(大众推出了第五代高尔夫GT)
- 换代在即,现在是抄底 7.5代 高尔夫的最佳时机吗(换代在即现在是抄底)
- 2020年大众7.5代高尔夫R终结特别版 最后的呐喊(2020年大众7.5代高尔夫R终结特别版)
热门推荐
- php如何对文本框输入小数的小数点(PHP保留两位小数的几种方法)
- vue本地图片切换(vue动态加载本地图片的处理方法)
- 如何编写错误日志才更容易排查问题
- php建造者模式实例(PHP工厂模式、单例模式与注册树模式实例详解)
- Sql Server常用系统存储过程
- 微信小程序开发完整操作流程(微信小程序开发之组件设计规范)
- idea的tomcat怎么关闭(解决Idea的tomcat启动报多个listener的错误问题)
- mysql数据库基本增删改查基本语句(MySQL表的增删改查基础教程)
- mybatis 一对多条件查询(mybatis collection 多条件查询的实现方法)
- docker容器启动执行脚本(在docker容器中使用非root用户执行脚本操作)
排行榜
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9