南强小屋 Design By 杰米
在web页面中,需要改变多个元素的位置,可以通过元素拖动来实现。HTML5中加入了一个全局属性draggable,通过设置true/false来控制元素是否可拖动。
下面以图片拖动为例,用jQuery来实现:页面上有多个图片,把一个图片拖动到其他两个图片中间,就可以将这个图片的位置插入到两图之间。
复制代码 代码如下:
<!DOCTYPE html>
<html>
<head>
<style>
.img-div img {
width:200px;
height:200px;
float: left;
}
.img-div {
float: left;
}
.drop-left,.drop-right {
width: 50px;
height: 200px;
float: left;
}
</style>
<script src="/UploadFiles/2021-04-02/jquery.min.js"><script>
$(document).ready(function() {
// 正在拖动的图片的父级DIV
var $srcImgDiv = null;
// 开始拖动
$(".img-div img").bind("dragstart", function() {
$srcImgDiv = $(this).parent();
});
// 拖动到.drop-left,.drop-right上方时触发的事件
$(".drop-left,.drop-right").bind("dragover", function(event) {
// 必须通过event.preventDefault()来设置允许拖放
event.preventDefault();
});
// 结束拖动放开鼠标的事件
$(".drop-left").bind("drop", function(event) {
event.preventDefault();
if($srcImgDiv[0] != $(this).parent()[0]) {
$(this).parent().before($srcImgDiv);
}
});
$(".drop-right").bind("drop", function(event) {
event.preventDefault();
if($srcImgDiv[0] != $(this).parent()[0]) {
$(this).parent().after($srcImgDiv);
}
});
});
</script>
</head>
<body>
<div class="img-div">
<div class="drop-left"></div>
<img src="/UploadFiles/2021-04-02/6864556.jpg"><div class="drop-right"></div>
</div>
<div class="img-div">
<div class="drop-left"></div>
<img src="/UploadFiles/2021-04-02/6695960.jpg"><div class="drop-right"></div>
</div>
<div class="img-div">
<div class="drop-left"></div>
<img src="/UploadFiles/2021-04-02/6683901.jpg"><div class="drop-right"></div>
</div>
<div class="img-div">
<div class="drop-left"></div>
<img src="/UploadFiles/2021-04-02/5121337.jpg"><div class="drop-right"></div>
</div>
</body>
</html>
dragstart是开始拖动元素的事件,dragover是拖动到元素上方的事件,drop是拖动结束松开鼠标的事件。
draggable="true"表示img元素是可以拖动的,不过实际上img默认就是可拖动的,所以这个属性也可以去掉,如果要拖动div元素那么就需要设置draggable="true"。
class为drop-left和drop-right的div元素放在图片的左右侧,用于接收其他图片拖动到这个位置。

下面以图片拖动为例,用jQuery来实现:页面上有多个图片,把一个图片拖动到其他两个图片中间,就可以将这个图片的位置插入到两图之间。
复制代码 代码如下:
<!DOCTYPE html>
<html>
<head>
<style>
.img-div img {
width:200px;
height:200px;
float: left;
}
.img-div {
float: left;
}
.drop-left,.drop-right {
width: 50px;
height: 200px;
float: left;
}
</style>
<script src="/UploadFiles/2021-04-02/jquery.min.js"><script>
$(document).ready(function() {
// 正在拖动的图片的父级DIV
var $srcImgDiv = null;
// 开始拖动
$(".img-div img").bind("dragstart", function() {
$srcImgDiv = $(this).parent();
});
// 拖动到.drop-left,.drop-right上方时触发的事件
$(".drop-left,.drop-right").bind("dragover", function(event) {
// 必须通过event.preventDefault()来设置允许拖放
event.preventDefault();
});
// 结束拖动放开鼠标的事件
$(".drop-left").bind("drop", function(event) {
event.preventDefault();
if($srcImgDiv[0] != $(this).parent()[0]) {
$(this).parent().before($srcImgDiv);
}
});
$(".drop-right").bind("drop", function(event) {
event.preventDefault();
if($srcImgDiv[0] != $(this).parent()[0]) {
$(this).parent().after($srcImgDiv);
}
});
});
</script>
</head>
<body>
<div class="img-div">
<div class="drop-left"></div>
<img src="/UploadFiles/2021-04-02/6864556.jpg"><div class="drop-right"></div>
</div>
<div class="img-div">
<div class="drop-left"></div>
<img src="/UploadFiles/2021-04-02/6695960.jpg"><div class="drop-right"></div>
</div>
<div class="img-div">
<div class="drop-left"></div>
<img src="/UploadFiles/2021-04-02/6683901.jpg"><div class="drop-right"></div>
</div>
<div class="img-div">
<div class="drop-left"></div>
<img src="/UploadFiles/2021-04-02/5121337.jpg"><div class="drop-right"></div>
</div>
</body>
</html>
dragstart是开始拖动元素的事件,dragover是拖动到元素上方的事件,drop是拖动结束松开鼠标的事件。
draggable="true"表示img元素是可以拖动的,不过实际上img默认就是可拖动的,所以这个属性也可以去掉,如果要拖动div元素那么就需要设置draggable="true"。
class为drop-left和drop-right的div元素放在图片的左右侧,用于接收其他图片拖动到这个位置。

标签:
拖动图片,改变顺序
南强小屋 Design By 杰米
广告合作:本站广告合作请联系QQ:858582 申请时备注:广告合作(否则不回)
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
南强小屋 Design By 杰米
暂无js实现图片拖动改变顺序附图的评论...
RTX 5090要首发 性能要翻倍!三星展示GDDR7显存
三星在GTC上展示了专为下一代游戏GPU设计的GDDR7内存。
首次推出的GDDR7内存模块密度为16GB,每个模块容量为2GB。其速度预设为32 Gbps(PAM3),但也可以降至28 Gbps,以提高产量和初始阶段的整体性能和成本效益。
据三星表示,GDDR7内存的能效将提高20%,同时工作电压仅为1.1V,低于标准的1.2V。通过采用更新的封装材料和优化的电路设计,使得在高速运行时的发热量降低,GDDR7的热阻比GDDR6降低了70%。