Jquery寫一個鼠標拖動效果實現(xiàn)原理與代碼
更新時間:2012年12月24日 09:35:48 作者:
近日項目中要做一個鼠標拖拽層的效果,于是手動使用Jquery做了一個,發(fā)出來跟大伙兒分享一下,并希望能得到高手的指點,如何有高手改進的話,在下不勝感激
近日項目中要做一個鼠標拖拽層的效果,于是手動使用Jquery做了一個,發(fā)出來跟大伙兒分享一下,并希望能得到高手的指點,如果哪位大俠覺得我的思路和代碼不正確或者需要改進的話,希望能指點一二,在下感激不盡。
我的思路是這樣的:
1、在鼠標按下的時候,捕獲鼠標的當前位置;
2、得到要移動對象的當前位置信息;
3、鼠標移動時,計算鼠標移動的距離,將這個距離更新到對象的位置,在我的代碼中,我試用絕對定位來表示對象的位置;
4、當鼠標移出對象或者鼠標彈起的時候,則認為對象處于不能移動的狀態(tài)。這個在我的代碼中使用一個bool類型的變量isMouseDown表示,當這個變量為true的時候,則說明對象處于可移動狀態(tài),如果為false的時候,表示對象處于不可移動狀態(tài)。鼠標移出對象或者彈出的時候,就將isMouseDown置為false。
好了,思路就是這樣,下面將代碼貼出來,如果我的思路中表達的不清楚的話,可以在代碼中看出來:
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" >
<head>
<title>使用鼠標拖動層代碼</title>
<style type="text/css">
#Main
{
width:400px;
height:400px;
position:absolute;
top:10px;
left:0;
border:1px solid #CCC;
border-radius:5px;
background-color:Green;
}
h3
{
margin:0;
width:400px;
height:40px;
background-color:Gray;
cursor:move;
line-height:40px;
border-radius:5px 5px 0 0;
}
</style>
<script type="text/javascript" src="http://code.jquery.com/jquery-1.7.min.js"></script>
<script type="text/javascript">
//注冊一個Jquery的鼠標拖動函數(shù),參數(shù)為要拖動的對象
$.fn.extend({ SliderObject: function (objMoved) {
var isMouseDown = false; //鼠標是否按下
var mouseDownPosiX;
var mouseDownPosiY;
var InitPositionX;
var InitPositionY;
var obj = $(objMoved) == undefined ? $(this) : $(objMoved);
obj.mousedown(function (e) {
//當鼠標按下時捕獲鼠標位置以及對象的當前位置
mouseDownPosiX = e.pageX;
mouseDownPosiY = e.pageY;
isMouseDown = true;
InitPositionX = obj.css("left").replace("px", "");
InitPositionY = obj.css("top").replace("px", "");
}).mousemove(function (e) {
//當鼠標按下并且移動時,首先判斷鼠標是否在當前焦點,以及鼠標是否已經(jīng)彈起,
if ($(this).is(":focus") && isMouseDown) {
var tempX = parseInt(e.pageX) - parseInt(mouseDownPosiX) + parseInt(InitPositionX);
var tempY = parseInt(e.pageY) - parseInt(mouseDownPosiY) + parseInt(InitPositionY);
obj.css("left", tempX + "px").css("top", tempY + "px");
}
//當鼠標彈起或者離開元素時,將鼠標彈起置為false,不移動對象
}).mouseup(function () {
isMouseDown = false;
}).mouseleave(function () {
isMouseDown = false;
});
}
});
$(document).ready(function () {
$("#Slider").SliderObject($("#Main"));
})
</script>
</head>
<body>
<div id="Main">
<h3>鼠標放在這里拖動我</h3>
<div id="Container">可以使用鼠標拖動的層</div>
</div>
</body>
</html>
我的思路是這樣的:
1、在鼠標按下的時候,捕獲鼠標的當前位置;
2、得到要移動對象的當前位置信息;
3、鼠標移動時,計算鼠標移動的距離,將這個距離更新到對象的位置,在我的代碼中,我試用絕對定位來表示對象的位置;
4、當鼠標移出對象或者鼠標彈起的時候,則認為對象處于不能移動的狀態(tài)。這個在我的代碼中使用一個bool類型的變量isMouseDown表示,當這個變量為true的時候,則說明對象處于可移動狀態(tài),如果為false的時候,表示對象處于不可移動狀態(tài)。鼠標移出對象或者彈出的時候,就將isMouseDown置為false。
好了,思路就是這樣,下面將代碼貼出來,如果我的思路中表達的不清楚的話,可以在代碼中看出來:
復制代碼 代碼如下:
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" >
<head>
<title>使用鼠標拖動層代碼</title>
<style type="text/css">
#Main
{
width:400px;
height:400px;
position:absolute;
top:10px;
left:0;
border:1px solid #CCC;
border-radius:5px;
background-color:Green;
}
h3
{
margin:0;
width:400px;
height:40px;
background-color:Gray;
cursor:move;
line-height:40px;
border-radius:5px 5px 0 0;
}
</style>
<script type="text/javascript" src="http://code.jquery.com/jquery-1.7.min.js"></script>
<script type="text/javascript">
//注冊一個Jquery的鼠標拖動函數(shù),參數(shù)為要拖動的對象
$.fn.extend({ SliderObject: function (objMoved) {
var isMouseDown = false; //鼠標是否按下
var mouseDownPosiX;
var mouseDownPosiY;
var InitPositionX;
var InitPositionY;
var obj = $(objMoved) == undefined ? $(this) : $(objMoved);
obj.mousedown(function (e) {
//當鼠標按下時捕獲鼠標位置以及對象的當前位置
mouseDownPosiX = e.pageX;
mouseDownPosiY = e.pageY;
isMouseDown = true;
InitPositionX = obj.css("left").replace("px", "");
InitPositionY = obj.css("top").replace("px", "");
}).mousemove(function (e) {
//當鼠標按下并且移動時,首先判斷鼠標是否在當前焦點,以及鼠標是否已經(jīng)彈起,
if ($(this).is(":focus") && isMouseDown) {
var tempX = parseInt(e.pageX) - parseInt(mouseDownPosiX) + parseInt(InitPositionX);
var tempY = parseInt(e.pageY) - parseInt(mouseDownPosiY) + parseInt(InitPositionY);
obj.css("left", tempX + "px").css("top", tempY + "px");
}
//當鼠標彈起或者離開元素時,將鼠標彈起置為false,不移動對象
}).mouseup(function () {
isMouseDown = false;
}).mouseleave(function () {
isMouseDown = false;
});
}
});
$(document).ready(function () {
$("#Slider").SliderObject($("#Main"));
})
</script>
</head>
<body>
<div id="Main">
<h3>鼠標放在這里拖動我</h3>
<div id="Container">可以使用鼠標拖動的層</div>
</div>
</body>
</html>
相關文章
jquery學習筆記 用jquery實現(xiàn)無刷新登錄
為了防止以后好久不用生疏,在這里記下,供剛開始學習jquery的童鞋們借鑒,我也是剛開始學jquery,有什么寫的不對的地方,還請大家指出錯誤,共同進步。2011-08-08jQuery動態(tài)添加.active 實現(xiàn)導航效果代碼思路詳解
這篇文章主要介紹了jQuery動態(tài)添加.active 實現(xiàn)導航效果代碼思路詳解,需要的朋友可以參考下2017-08-08ashx文件獲取$.ajax()方法發(fā)送的數(shù)據(jù)
這篇文章主要介紹了ashx文件獲取$.ajax()方法發(fā)送的數(shù)據(jù)的相關資料,非常不錯,具有參考借鑒價值,需要的朋友可以參考下2016-05-05jquery和javascript中如何將一元素的內容賦給另一元素
將一元素的內容賦給另一元素,在某些情況下還是比較實用的,下面為大家講解下jquery和javascript中是如何實現(xiàn)的2014-01-01jQuery實現(xiàn)花式輪播之圣誕節(jié)禮物傳送效果
這篇文章主要介紹了jQuery實現(xiàn)花式輪播之圣誕節(jié)禮物傳送效果,需要的朋友可以參考下2016-12-12