手机
当前位置:查字典教程网 >编程开发 >Javascript教程 >js实现图片拖动改变顺序附图
js实现图片拖动改变顺序附图
摘要:在web页面中,需要改变多个元素的位置,可以通过元素拖动来实现。HTML5中加入了一个全局属性draggable,通过设置true/fals...

在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="http://ajax.googleapis.com/ajax/libs/jquery/1.8.0/jquery.min.js"></script>

<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>

<div></div>

<img src="http://photos.tuchong.com/38538/f/6864556.jpg" draggable="true">

<div></div>

</div>

<div>

<div></div>

<img src="http://photos.tuchong.com/349669/f/6695960.jpg" draggable="true">

<div></div>

</div>

<div>

<div></div>

<img src="http://photos.tuchong.com/349669/f/6683901.jpg" draggable="true">

<div></div>

</div>

<div>

<div></div>

<img src="http://photos.tuchong.com/349669/f/5121337.jpg" draggable="true">

<div></div>

</div>

</body>

</html>

dragstart是开始拖动元素的事件,dragover是拖动到元素上方的事件,drop是拖动结束松开鼠标的事件。

draggable="true"表示img元素是可以拖动的,不过实际上img默认就是可拖动的,所以这个属性也可以去掉,如果要拖动div元素那么就需要设置draggable="true"。

class为drop-left和drop-right的div元素放在图片的左右侧,用于接收其他图片拖动到这个位置。

1

【js实现图片拖动改变顺序附图】相关文章:

jquery实现图片左右切换的方法

JS实现简洁、全兼容的拖动层实例

javascript实现可拖动变色并关闭层窗口实例

js实现鼠标经过表格行变色的方法

js实现鼠标划过给div加透明度的方法

javascript实现炫酷的拖动分页

JS函数实现鼠标指向图片后显示大图代码

超强图片数量上传无限制

javascript实现动态改变层大小的方法

js+css实现回到顶部按钮(back to top)

精品推荐
分类导航