JS HTML5实现拖拽移动列表效果


Posted in Javascript onAugust 27, 2020

练习HTML5中的拖放API,实现列表拖拽移动!参考文章:JS HTML5拖拽上传图片预览

HTML5拖拽移动列表实现思路:

 1.循环设置每个子项的draggable属性,以及设置拖动标记(不会多个或全部子项都移动)
 2.每次进入投放区,则检测时候有拖放标记,有则添加dom元素,以此类推

另一种实现思路是:可以利用拖放中DataTransfer对象作为属性,用setData()和getData()方法传递每个拖动的子项的id等数据,找到指定的子项进行移动….待实验。。。

HTML:

//空列表
<div id="box"></div>
//内容列表
<ul id="con">
 <li>第1项</li>
 <li>第2项</li>
 <li>第3项</li>
 <li>第4项</li>
</ul>

JS:

<script>
 function $(id) {
 return document.getElementById(id);
 }
 var con = $("con");
 var box = $("box");
 var liDoms = document.getElementsByTagName("li");
 var i = 0,
 len = liDoms.length;
 //循环设置每个子项的draggable属性,以及时候拖动标记
 for (; i < len; i += 1) {
 liDoms[i].draggable = 'true';
 liDoms[i].flag = false;
 liDoms[i].ondragstart = function() {
 this.flag = true;
 };
 liDoms[i].ondragend = function() {
 this.flag = false;
 };
 }

 //投放区事件
 $("box").ondragenter = function(e) {
 e.preventDefault();
 console.log('进入');

 };
 $("box").ondragover = function(e) {
 e.preventDefault();
 console.log('移动');
 };
 $("box").ondragleave = function(e) {
 e.preventDefault();
 console.log('离开');
 };
 $("box").ondrop = function(e) {

 e.preventDefault();
 for (var i = 0; i < liDoms.length; i += 1) {

 if (liDoms[i].flag) {
 box.appendChild(liDoms[i]);
 }
 }

 console.log('成功');

 };
 //投放区事件
 $("con").ondragenter = function(e) {
 e.preventDefault();
 console.log('进入');

 };
 $("con").ondragover = function(e) {
 e.preventDefault();
 console.log('移动');
 };
 $("con").ondragleave = function(e) {
 e.preventDefault();
 console.log('离开');
 };
 $("con").ondrop = function(e) {

 e.preventDefault();
 for (var i = 0; i < liDoms.length; i += 1) {

 if (liDoms[i].flag) { //此时获得是时box对象下li,而不是原容器的li了
 $("con").appendChild(liDoms[i]);
 }
 }

 console.log('成功');

 };
 </script>

效果图:

JS HTML5实现拖拽移动列表效果

以上就是本文的全部内容,希望对大家的学习有所帮助。

Javascript 相关文章推荐
层序遍历在ExtJs的TreePanel中的应用
Oct 16 Javascript
jQuery打印指定区域Html页面并自动分页
Jul 04 Javascript
简介JavaScript中Math.cos()余弦方法的使用
Jun 15 Javascript
JavaScript如何实现组合列表框中元素移动效果
Mar 01 Javascript
利用jquery实现下拉框的禁用与启用
Dec 07 Javascript
vue init失败简单解决方法(终极版)
Dec 22 Javascript
Vue在页面右上角实现可悬浮/隐藏的系统菜单
May 04 Javascript
vue.js中使用echarts实现数据动态刷新功能
Apr 16 Javascript
Vue 动态添加路由及生成菜单的方法示例
Jun 20 Javascript
基于jQuery的时间戳与日期间的转化
Jun 21 jQuery
vue 设置 input 为不可以编辑的实现方法
Sep 19 Javascript
微信小程序实现打卡签到页面
Sep 21 Javascript
浅谈$('div a') 与$('div&gt;a')的区别
Jul 18 #Javascript
浅析JavaScript中的array数组类型系统
Jul 18 #Javascript
基于jQuery.validate及Bootstrap的tooltip开发气泡样式的表单校验组件思路详解
Jul 18 #Javascript
javascript时间差插件分享
Jul 18 #Javascript
如何用js实现鼠标向上滚动时浮动导航
Jul 18 #Javascript
终于实现了!精彩的jquery弹幕效果
Jul 18 #Javascript
全面解析JavaScript中“&amp;&amp;”和“||”操作符(总结篇)
Jul 18 #Javascript
You might like
dedecms系统的广告设置代码 基础版本
2010/04/09 PHP
PHP模板引擎Smarty内建函数详解
2016/04/11 PHP
PHP读书笔记整理_结构语句详解
2016/07/01 PHP
PHP不使用递归的无限级分类简单实例
2016/11/05 PHP
php设计模式之职责链模式实例分析【星际争霸游戏案例】
2020/03/27 PHP
在百度知道团队中快速审批新成员的js脚本
2014/02/02 Javascript
js实现按钮控制图片360度翻转特效的方法
2015/02/17 Javascript
jQuery筛选数组之grep、each、inArray、map的用法及遍历json对象
2016/06/20 Javascript
jQuery实用小技巧_输入框文字获取和失去焦点的简单实例
2016/08/25 Javascript
浅谈JS中的三种字符串连接方式及其性能比较
2016/09/02 Javascript
JavaScript实现图片懒加载(Lazyload)
2016/11/28 Javascript
JQuery Dialog对话框 不能通过Esc关闭的原因分析及解决办法
2017/01/18 Javascript
浅谈angularjs $http提交数据探索
2017/01/20 Javascript
js前端实现图片懒加载(lazyload)的两种方式
2017/04/24 Javascript
bootstrap table表格使用方法详解
2017/04/26 Javascript
NodeJs使用Mysql模块实现事务处理实例
2017/05/31 NodeJs
ajax请求+vue.js渲染+页面加载的示例
2018/02/11 Javascript
使用node搭建自动发图文微博机器人的方法
2019/03/22 Javascript
小程序封装路由文件和路由方法(5种全解析)
2019/05/26 Javascript
vue+element加入签名效果(移动端可用)
2019/06/17 Javascript
vue实现简单计算商品价格
2020/09/14 Javascript
[04:44]显微镜下的DOTA2第二期——你所没有注意到的细节
2014/06/20 DOTA
Python微信企业号开发之回调模式接收微信端客户端发送消息及被动返回消息示例
2017/08/21 Python
Python3实现抓取javascript动态生成的html网页功能示例
2017/08/22 Python
python NumPy ndarray二维数组 按照行列求平均实例
2019/11/26 Python
python在一个范围内取随机数的简单实例
2020/08/16 Python
python根据字典的键来删除元素的方法
2020/08/16 Python
香港化妆品经销商:我的公主
2016/08/05 全球购物
Sasa莎莎海外旗舰店:香港莎莎美妆平台
2018/03/21 全球购物
英国Iceland杂货店:网上食品购物
2020/12/16 全球购物
办公室前台岗位职责
2014/01/04 职场文书
公益活动策划方案
2014/01/09 职场文书
社区母亲节活动记录
2014/03/06 职场文书
房产转让协议书
2014/04/11 职场文书
羽毛球比赛策划方案
2014/06/13 职场文书
Python中with上下文管理协议的作用及用法
2022/03/18 Python