js實現(xiàn)圖片拖動改變順序附圖
更新時間:2014年05月13日 17:57:37 作者:
需要改變多個元素的位置,可以通過元素拖動來實現(xiàn),下面以圖片拖動為例,用jQuery來實現(xiàn),需要的朋友可以參考下
在web頁面中,需要改變多個元素的位置,可以通過元素拖動來實現(xiàn)。HTML5中加入了一個全局屬性draggable,通過設(shè)置true/false來控制元素是否可拖動。
下面以圖片拖動為例,用jQuery來實現(xiàn):頁面上有多個圖片,把一個圖片拖動到其他兩個圖片中間,就可以將這個圖片的位置插入到兩圖之間。
<!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上方時觸發(fā)的事件
$(".drop-left,.drop-right").bind("dragover", function(event) {
// 必須通過event.preventDefault()來設(shè)置允許拖放
event.preventDefault();
});
// 結(jié)束拖動放開鼠標的事件
$(".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="http://photos.tuchong.com/38538/f/6864556.jpg" draggable="true">
<div class="drop-right"></div>
</div>
<div class="img-div">
<div class="drop-left"></div>
<img src="http://photos.tuchong.com/349669/f/6695960.jpg" draggable="true">
<div class="drop-right"></div>
</div>
<div class="img-div">
<div class="drop-left"></div>
<img src="http://photos.tuchong.com/349669/f/6683901.jpg" draggable="true">
<div class="drop-right"></div>
</div>
<div class="img-div">
<div class="drop-left"></div>
<img src="http://photos.tuchong.com/349669/f/5121337.jpg" draggable="true">
<div class="drop-right"></div>
</div>
</body>
</html>
dragstart是開始拖動元素的事件,dragover是拖動到元素上方的事件,drop是拖動結(jié)束松開鼠標的事件。
draggable="true"表示img元素是可以拖動的,不過實際上img默認就是可拖動的,所以這個屬性也可以去掉,如果要拖動div元素那么就需要設(shè)置draggable="true"。
class為drop-left和drop-right的div元素放在圖片的左右側(cè),用于接收其他圖片拖動到這個位置。
下面以圖片拖動為例,用jQuery來實現(xiàn):頁面上有多個圖片,把一個圖片拖動到其他兩個圖片中間,就可以將這個圖片的位置插入到兩圖之間。
復(fù)制代碼 代碼如下:
<!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上方時觸發(fā)的事件
$(".drop-left,.drop-right").bind("dragover", function(event) {
// 必須通過event.preventDefault()來設(shè)置允許拖放
event.preventDefault();
});
// 結(jié)束拖動放開鼠標的事件
$(".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="http://photos.tuchong.com/38538/f/6864556.jpg" draggable="true">
<div class="drop-right"></div>
</div>
<div class="img-div">
<div class="drop-left"></div>
<img src="http://photos.tuchong.com/349669/f/6695960.jpg" draggable="true">
<div class="drop-right"></div>
</div>
<div class="img-div">
<div class="drop-left"></div>
<img src="http://photos.tuchong.com/349669/f/6683901.jpg" draggable="true">
<div class="drop-right"></div>
</div>
<div class="img-div">
<div class="drop-left"></div>
<img src="http://photos.tuchong.com/349669/f/5121337.jpg" draggable="true">
<div class="drop-right"></div>
</div>
</body>
</html>
dragstart是開始拖動元素的事件,dragover是拖動到元素上方的事件,drop是拖動結(jié)束松開鼠標的事件。
draggable="true"表示img元素是可以拖動的,不過實際上img默認就是可拖動的,所以這個屬性也可以去掉,如果要拖動div元素那么就需要設(shè)置draggable="true"。
class為drop-left和drop-right的div元素放在圖片的左右側(cè),用于接收其他圖片拖動到這個位置。

您可能感興趣的文章:
相關(guān)文章
ES6?關(guān)鍵字?let?和?ES5?及關(guān)鍵字?var?的區(qū)別解析
var可以穿透控制語句、條件語句這樣的作用域,導(dǎo)致變量沖突經(jīng)常發(fā)生,這篇文章主要介紹了ES6?關(guān)鍵字?let?和?ES5?及關(guān)鍵字?var?的區(qū)別,需要的朋友可以參考下2022-09-09javascript獲取指定區(qū)間范圍隨機數(shù)的方法
下面小編就為大家?guī)硪黄猨avascript獲取指定區(qū)間范圍隨機數(shù)的方法。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-09-09使用uniapp打包微信小程序時主包和vendor.js過大解決(uniCloud的插件分包)
每個使用分包小程序必定含有一個主包,所謂的主包,即放置默認啟動頁面/TabBar頁面,以及一些所有分包都需用到公共資源/JS 腳本,下面這篇文章主要給大家介紹了關(guān)于使用uniapp打包微信小程序時主包和vendor.js過大解決的相關(guān)資料,,需要的朋友可以參考下2023-02-02IE與Firefox在JavaScript上的7個不同寫法小結(jié)
盡管那需要用長串的、沉悶的不同分支代碼來應(yīng)付不同瀏覽器的日子已經(jīng)過去,偶爾還是有必要做一些簡單的區(qū)分和目標檢測來確保某塊代碼能在用戶的機器上正常運行。2009-09-09