本文实例为大家分享了jquery实现拖拽添加元素的具体代码,供大家参考,具体内容如下
需求
1.页面上有两个不同的容器,拖拽a容器的元素添加到b容器中;
2.a保持原位不dogn动,b增加新的元素,要实现的效果如下:
3.点击b容器中的元素移除元素
首先准备两个容器
页面效果如下
<div class="bigBox"> <div id="aBox"> <p class="drag" draggable="true" data-id="我是a元素的第一个">我是a元素</p> <p class="drag" draggable="true" data-id="我是a元素的第二个">我是a元素</p> <p class="drag" draggable="true" data-id="我是a元素的第三个">我是a元素</p> <p class="drag" draggable="true" data-id="我是a元素的第四个">我是a元素</p> </div> <div id="bBox"> </div> </div>
在css中定义好样式,区分两个容器
.bigBox { display: flex; width: 100%; height: 400px; } #aBox { width: 40%; height: 100%; background-color: pink; } #aBox > p { line-height: 30px; padding: 4px; background-color: yellow; } #bBox { width: 40%; height: 100%; background-color: #00BCF4; } .span { border: 1px slid #ccc; border-radius: 12px; display: inline-block; padding: 3px; background-color: red; }
封装一个添加元素的方法
function add(addId, htmlId) { var listItem = { // 接收绑定的属性值,并赋值给数组的某一项 name: addId } var obj = {}; var html = '' coloList.push(listItem) coloList = coloList.reduce(function(item, next) { // 对数组进行去重处理 obj[next.name] "true" class="span" data-id=' + coloList[i].name + ' >' + coloList[i].name + '</span>' } htmlId.html(html) // b容器要展示的数据 }
以下是拖拽的方法函数
var coloList = [] $(document).on('dragstart', '.drag', function(e) { // 拖拽事件绑定到元素上 var dudataId = $(this).attr("data-id") // 获取到元素绑定的属性值 $(document).on('dragenter', '#bBox', function() { }) $(document).on('dragover', '#bBox', function() { // 这行代码一定要有,阻止事件的默认行为,才能触发鼠标放下的事件 event.preventDefault() }) $('#bBox').on('drop', function(e) { // // 鼠标放下事件被触发把元素添加到bbox中 add(dudataId, $('#bBox')) }) $(document).on('drop', '#bBox', function() { // 定时器解绑事件,不然会一直绑定事件,重复添加数据 var timer = setInterval(function() { $('#bBox').off('dragover') $('#bBox').off('dragenter') $('#bBox').off('drop') clearInterval(timer); }, 30) }) })
移除bbox的事件的方法
function remove(removeId, htmlId) { console.log(removeId, htmlId) var index = -1 var html = '' // var list = coloList for (var k = 0; k < coloList.length; k++) { if (removeId === coloList[k].name) { index = k break } else { index = -1 } } if (index != -1) { coloList.splice(index, 1) // coloList = list for (var i = 0; i < coloList.length; i++) { // 对去重后的数组渲染到页面 html += '<span class="span" data-id=' + coloList[i].name + '>' + coloList[i].name + '</span>' } htmlId.html(html) } else { alert('暂无可移除的维度') } }
绑定点击事件
$('#bBox').on('click', '.span', function(e) { remove($(this).attr("data-id"), $('#bBox')) // 参数:动态添加的属性值当前点击的元素,度量列表,维度html })
这样就完成了呀。
以下是完整的代码:
<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title></title> <style type="text/css"> .bigBox { display: flex; width: 100%; height: 400px; } #aBox { width: 40%; height: 100%; background-color: pink; } #aBox > p { line-height: 30px; padding: 4px; background-color: yellow; } #bBox { width: 40%; height: 100%; background-color: #00BCF4; } .span { border: 1px slid #ccc; border-radius: 12px; display: inline-block; padding: 3px; background-color: red; } </style> </head> <body> <div class="bigBox"> <div id="aBox"> <p class="drag" draggable="true" data-id="我是a元素的第一个">我是a元素</p> <p class="drag" draggable="true" data-id="我是a元素的第二个">我是a元素</p> <p class="drag" draggable="true" data-id="我是a元素的第三个">我是a元素</p> <p class="drag" draggable="true" data-id="我是a元素的第四个">我是a元素</p> </div> <div id="bBox"> </div> </div> <script src="/UploadFiles/2021-04-02/jquery.js">以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
风云阁资源网 Design By www.bgabc.com
广告合作:本站广告合作请联系QQ:858582 申请时备注:广告合作(否则不回)
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
风云阁资源网 Design By www.bgabc.com
暂无评论...
更新日志
2024年11月15日
2024年11月15日
- 黄乙玲1988-无稳定的爱心肝乱糟糟[日本东芝1M版][WAV+CUE]
- 群星《我们的歌第六季 第3期》[320K/MP3][70.68MB]
- 群星《我们的歌第六季 第3期》[FLAC/分轨][369.48MB]
- 群星《燃!沙排少女 影视原声带》[320K/MP3][175.61MB]
- 乱斗海盗瞎6胜卡组推荐一览 深暗领域乱斗海盗瞎卡组分享
- 炉石传说乱斗6胜卡组分享一览 深暗领域乱斗6胜卡组代码推荐
- 炉石传说乱斗本周卡组合集 乱斗模式卡组最新推荐
- 佟妍.2015-七窍玲珑心【万马旦】【WAV+CUE】
- 叶振棠陈晓慧.1986-龙的心·俘虏你(2006复黑限量版)【永恒】【WAV+CUE】
- 陈慧琳.1998-爱我不爱(国)【福茂】【WAV+CUE】
- 咪咕快游豪礼放送,百元京东卡、海量欢乐豆就在咪咕咪粉节!
- 双11百吋大屏焕新“热”,海信AI画质电视成最大赢家
- 海信电视E8N Ultra:真正的百吋,不止是大!
- 曾庆瑜1990-曾庆瑜历年精选[派森][WAV+CUE]
- 叶玉卿1999-深情之选[飞图][WAV+CUE]