杰网资源 Design By www.escxy.com
本文实例为大家分享了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.escxy.com
广告合作:本站广告合作请联系QQ:858582 申请时备注:广告合作(否则不回)
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
杰网资源 Design By www.escxy.com
暂无评论...
《魔兽世界》大逃杀!60人新游玩模式《强袭风暴》3月21日上线
暴雪近日发布了《魔兽世界》10.2.6 更新内容,新游玩模式《强袭风暴》即将于3月21 日在亚服上线,届时玩家将前往阿拉希高地展开一场 60 人大逃杀对战。
艾泽拉斯的冒险者已经征服了艾泽拉斯的大地及遥远的彼岸。他们在对抗世界上最致命的敌人时展现出过人的手腕,并且成功阻止终结宇宙等级的威胁。当他们在为即将于《魔兽世界》资料片《地心之战》中来袭的萨拉塔斯势力做战斗准备时,他们还需要在熟悉的阿拉希高地面对一个全新的敌人──那就是彼此。在《巨龙崛起》10.2.6 更新的《强袭风暴》中,玩家将会进入一个全新的海盗主题大逃杀式限时活动,其中包含极高的风险和史诗级的奖励。
《强袭风暴》不是普通的战场,作为一个独立于主游戏之外的活动,玩家可以用大逃杀的风格来体验《魔兽世界》,不分职业、不分装备(除了你在赛局中捡到的),光是技巧和战略的强弱之分就能决定出谁才是能坚持到最后的赢家。本次活动将会开放单人和双人模式,玩家在加入海盗主题的预赛大厅区域前,可以从强袭风暴角色画面新增好友。游玩游戏将可以累计名望轨迹,《巨龙崛起》和《魔兽世界:巫妖王之怒 经典版》的玩家都可以获得奖励。




