四虎精品视频-四虎精品成人免费网站-四虎黄色网-四虎国产视频-国产免费91-国产蜜臀97一区二区三区

可以拖動(dòng)的div 實(shí)現(xiàn)代碼第1/2頁(yè)

要實(shí)現(xiàn)div的任意拖動(dòng),我們不妨分析一下整個(gè)過(guò)程。
當(dāng)鼠標(biāo)點(diǎn)擊div時(shí),觸發(fā)一個(gè)事件,讓div的位置屬性(left,top)隨著鼠標(biāo)位置變化而變化,當(dāng)鼠標(biāo)釋放后,div的位置屬性就用了鼠標(biāo)釋放時(shí)的位置。
鼠標(biāo)點(diǎn)擊時(shí)觸發(fā)事件是很容易做到的,只要在div的標(biāo)簽里加上onmouseclick就可以了,現(xiàn)在我們要解決的問(wèn)題是如何讓div的位置隨著鼠標(biāo)的位置變化而變化。
雖然這可能是一個(gè)很簡(jiǎn)單的推理過(guò)程,不過(guò)還是羅嗦點(diǎn)說(shuō)清楚吧。div的left和top是div左上角的坐標(biāo),當(dāng)我們把鼠標(biāo)移到div中點(diǎn)擊的時(shí)候,無(wú)疑鼠標(biāo)的坐標(biāo)和div的坐標(biāo)是不一致的,這時(shí)候如果我們簡(jiǎn)單的讓div的坐標(biāo)等于鼠標(biāo)的坐標(biāo),那么看起來(lái)的效果就不是那么完美了,所以我們先要得到鼠標(biāo)的坐標(biāo)和div坐標(biāo)的差,然后在鼠標(biāo)移動(dòng)到的時(shí)候,在鼠標(biāo)坐標(biāo)上減去這個(gè)差來(lái)得到div的坐標(biāo)(如果不太明白,那就先補(bǔ)習(xí)一下網(wǎng)頁(yè)的基礎(chǔ)知識(shí))。
接下來(lái)的事情就簡(jiǎn)單了,當(dāng)鼠標(biāo)移動(dòng)的時(shí)候,我們不斷的計(jì)算得到div的坐標(biāo),并改變,在鼠標(biāo)釋放的時(shí)候,這個(gè)事件就被移除。
整個(gè)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的事件對(duì)象,那么就用window.event
  //全局屬性,否則就用DOM二級(jí)標(biāo)準(zhǔn)的Event對(duì)象。
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ù)可以拖動(dòng)的div 實(shí)現(xiàn)代碼第1/2頁(yè),轉(zhuǎn)載需保留來(lái)源!

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

主站蜘蛛池模板: 天空骑士| 竹内纱里奈作品| 马子俊| 大珍珠演员表介绍| 译码器及其应用实验报告| 浪荡子的旅程电影| 小小少年电影完整版| 九九九九九九九伊人| 电影在线观看高清完整版免费| 无线新闻| 尹雪喜演的电影在线观看| 猿球崛起| 韩漫画未删减男同| 汤唯惊艳写真集| 安多卫视直播在线观看| 质量教育培训的首要内容是() (单选题)| 大学生做爰视频直播| cctv17农业农村频道在线直播| 成人的性行为免费| 色在线免费观看| 法律援助中心免费写诉状| 诈欺游戏电影| 猎兽神兵免费全集在线观看高清版| 笼中之怒| 陈百强电影| 湖北经视频道| 爱很简单简谱| 金敏喜个人简历| 卧虎演员表| 爱上特种兵电视剧免费观看完整版 | 恐怖地带| 雳剑 电视剧演员表| 德兰| 番金连| 哈尔的移动城堡日语版在线播放| 苹果恋爱多| http://www.douyin.com/| 崛井美月| 对你的爱歌词| 广西地图全图可放大| 夜魔3绝杀电影|