在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://m.survivalescaperooms.com/uploads/allimg/140514/10023R924_1.jpg" draggable="true"> 
<div></div> 
</div> 
<div> 
<div></div> 
<img src="http://m.survivalescaperooms.com/uploads/allimg/140514/100254V91_0.jpg" draggable="true"> 
<div></div> 
</div> 
<div> 
<div></div> 
<img src="http://m.survivalescaperooms.com/uploads/allimg/140514/10023R924_0.jpg" draggable="true"> 
<div></div> 
</div> 
<div> 
<div></div> 
<img src="http://m.survivalescaperooms.com/uploads/allimg/140514/1002226213_1.jpg" draggable="true"> 
<div></div> 
</div> 
</body> 
</html> 
新聞熱點
疑難解答
圖片精選