js實現圖片拖動改變順序

在web頁面中,需要改變多個元素的位置,可以通過元素拖動來實現。HTML5中加入瞭一個全局屬性draggable,通過設置true/false來控制元素是否可拖動。

下面以圖片拖動為例,用jQuery來實現:頁面上有多個圖片,把一個圖片拖動到其他兩個圖片中間,就可以將這個圖片的位置插入到兩圖之間。




	.img-p img {
		width:200px;
		height:200px;
		float: left;
	}
	.img-p {
		float: left;
	}
	.drop-left,.drop-right {
		width: 50px;
		height: 200px;
		float: left;
	}

<script src="https://ajax.googleapis.com/ajax/libs/jquery/1.8.0/jquery.min.js"></script>
<script>
	$(document).ready(function() {
		
		// 正在拖動的圖片的父級DIV
		var $srcImgDiv = null;

		// 開始拖動
		$(".img-p 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>


	

dragstart是開始拖動元素的事件,dragover是拖動到元素上方的事件,drop是拖動結束松開鼠標的事件。

draggable=”true”表示img元素是可以拖動的,不過實際上img默認就是可拖動的,所以這個屬性也可以去掉,如果要拖動p元素那麼就需要設置draggable=”true”。

class為drop-left和drop-right的p元素放在圖片的左右側,用於接收其他圖片拖動到這個位置。

作者:叉叉哥 轉載請註明出處:https://blog.csdn.net/xiao__gui/article/details/25695025

發佈留言