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