天天躁日日躁狠狠躁AV麻豆-天天躁人人躁人人躁狂躁-天天澡夜夜澡人人澡-天天影视香色欲综合网-国产成人女人在线视频观看-国产成人女人视频在线观看

可以拖動的div 實現(xiàn)代碼第1/2頁

要實現(xiàn)div的任意拖動,我們不妨分析一下整個過程。
當(dāng)鼠標(biāo)點擊div時,觸發(fā)一個事件,讓div的位置屬性(left,top)隨著鼠標(biāo)位置變化而變化,當(dāng)鼠標(biāo)釋放后,div的位置屬性就用了鼠標(biāo)釋放時的位置。
鼠標(biāo)點擊時觸發(fā)事件是很容易做到的,只要在div的標(biāo)簽里加上onmouseclick就可以了,現(xiàn)在我們要解決的問題是如何讓div的位置隨著鼠標(biāo)的位置變化而變化。
雖然這可能是一個很簡單的推理過程,不過還是羅嗦點說清楚吧。div的left和top是div左上角的坐標(biāo),當(dāng)我們把鼠標(biāo)移到div中點擊的時候,無疑鼠標(biāo)的坐標(biāo)和div的坐標(biāo)是不一致的,這時候如果我們簡單的讓div的坐標(biāo)等于鼠標(biāo)的坐標(biāo),那么看起來的效果就不是那么完美了,所以我們先要得到鼠標(biāo)的坐標(biāo)和div坐標(biāo)的差,然后在鼠標(biāo)移動到的時候,在鼠標(biāo)坐標(biāo)上減去這個差來得到div的坐標(biāo)(如果不太明白,那就先補習(xí)一下網(wǎng)頁的基礎(chǔ)知識)。
接下來的事情就簡單了,當(dāng)鼠標(biāo)移動的時候,我們不斷的計算得到div的坐標(biāo),并改變,在鼠標(biāo)釋放的時候,這個事件就被移除。
整個js函數(shù)如下:
function beginDrag(elementToDrag,event)
{
var deltaX=event.clientX-parseInt(elementToDrag.style.left);
var deltaY=event.clientY-parseInt(elementToDrag.style.top);
if(document.addEventListener)
{
document.addEventListener(”mousemove”,moveHandler,true);
document.addEventListener(”mouseup”,upHandler,true);
//document.addEventListener(”mouseout”,upHandler,true);
}
else if(document.attachEvent)
{
document.attachEvent(”onmousemove”,moveHandler);
document.attachEvent(”onmouseup”,upHandler);
//document.attachEvent(”onmouseout”,upHandler);
}
if(event.stopPropagation) event.stopPropagation();
else event.cancelBubble=true;
if(event.preventDefault) event.preventDefault();
else event.returnValue=false;
function moveHandler(e)
{
  if (!e) e=window.event; //如果是IE的事件對象,那么就用window.event
  //全局屬性,否則就用DOM二級標(biāo)準(zhǔn)的Event對象。
elementToDrag.style.left=(e.clientX-deltaX)+”px”;
elementToDrag.style.top=(e.clientY-deltaY)+”px”;
if(e.stopPropagation) e.stopPropagation();
else e.cancelBubble=true;
}
function upHandler(e)
{
if(document.removeEventListener)
{
document.removeEventListener(”mouseup”,upHandler,true);
document.removeEventListener(”mousemove”,moveHandler,true);}
else
{
document.detachEvent(”onmouseup”,upHandler);
document.detachEvent(”onmousemove”,moveHandler);}
}
if (!e) e=window.event;
if(e.stopPropagation) e.stopPropagation();
else e.cancelBubble=true;
}

JavaScript技術(shù)可以拖動的div 實現(xiàn)代碼第1/2頁,轉(zhuǎn)載需保留來源!

鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標(biāo)記有誤,請第一時間聯(lián)系我們修改或刪除,多謝。

主站蜘蛛池模板: 亚洲一卡久久4卡5卡6卡7卡 | 亚洲AV噜噜88 | 男男肉肉互插腐文 | 久久精品热只有精品 | 快播dvd吧 | 国产乱码伦人偷精品视频 | 亚洲国产精品VA在线看黑人 | 三男强一女90分钟在线观看 | jizzxxxx18中国内地 | 欧美精品中文字幕亚洲专区 | 亚洲无线码一区在线观看 | 男女久久久国产一区二区三区 | 攻把受做得合不拢腿play | 男人一进一出桶女人视频 | 欧美高清vivoesosexo18 | 国产午夜电影在线观看不卡 | 日日a.v拍夜夜添久久免费 | 久久精品国产亚洲AV天美18 | 97伦理电影在线不卡 | 超碰免费碰免费视频 | 亚洲国产AV一区二区三区四区 | 伊人亚洲AV久久无码精品 | 久久久精品免费免费直播 | 欧洲最大无人区免费高清完整版 | 色欲AV蜜臀AV在线观看麻豆 | 亚洲一区电影在线观看 | 人人爽天天碰狠狠添 | 成人免费一级毛片在线播放视频 | 精品性影院一区二区三区内射 | 欧美精品久久久久久久久大尺度 | 亚洲精品高清AV在线播放 | 18禁止看的免费污网站 | 伊人精品国产 | 含羞草国产亚洲精品岁国产精品 | 国产精品久久人妻拍拍水牛影视 | 亚洲国产中文字幕新在线 | 乱精品一区字幕二区 | 欧美 亚洲 日韩 中文2019 | caoporn 在线视频 | 高清观看ZSHH96的视频素材 | 麻美ゆま夫の目の前で犯 |