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

javascript 可以拖動的DIV(二)

function beginDrag(elementToDrag,event)
{
var =event.clientX-parseInt(elementToDrag.style.left);
var deltaY=event.clientY-parseInt(elementToDrag.style.top);
//這兒的deltaX/Y實際上就是得出鼠標和div的坐標差。
if(document.addEventListener)
//之所以在這兒加這樣一個判斷,是因為IE6和firefox對于Javascript的事件處理有不同的方法(IE7之后的版本開始符合W3C的標準)。
//document.addEventlistener如果是true的話,那就是firefox等支持W3C DOM標準的瀏覽器,IE6中注冊事件用attachEvent,而firefox等瀏覽器則是用addEventListener,語法如下所示。addEventListener函數(shù)的true參數(shù)表示可以捕捉事件。
{
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;
//這兒的判斷依然是考慮了不同的瀏覽器,stopPropagation是W3C DOM標準中使用的一個方法,用來取消事件的傳播。我們使用了document.addEventListener這個方法,瀏覽器會從document對象沿著DOM節(jié)點向下傳播到目標節(jié)點,注冊的事件處理程序就會運行,然后事件會回傳到父節(jié)點,如果父節(jié)點也有相應的事件處理程序,那么事件也會處理,為了避免這種情況,我們可以用stopPropagation來阻止事件的傳播,這個方法的作用就是讓其他元素對這個事件不可見。在IE6下,并沒有元素捕捉事件的過程,不過有這個術語叫做起泡的過程,IE6中所用的方法就是cancelBubble,用來取消起泡,表示這個事件已被處理,其他元素不用再看見了。
if(event.preventDefault) event.preventDefault();
else event.returnValue=false;
//這兒的preventDefault用來通知瀏覽器不要執(zhí)行與事件關聯(lián)的默認動作,returnValue用來取消發(fā)生事件的源元素的默認動作,大家應該能看出這是在不同瀏覽器下發(fā)揮相同的作用。
//以下就是拖動div中所用的關鍵函數(shù)了。
function moveHandler(e)
{
   if (!e) e=window.event; //如果是IE的事件對象,那么就用window.event
   //全局屬性,否則就用DOM二級標準的Event對象。
//在IE中,event是window的一個屬性,也就是一個全局變量,但是在W3C DOM中,event是發(fā)生事件的文檔對象的屬性。在這個程序中,event是什么并不重要,關鍵是我們要取得鼠標的坐標值,在IE中,e這個參數(shù)傳進來的時候,IE認不出來,所以我們就給e賦值為window.event。
elementToDrag.style.left=(e.clientX-deltaX)+"px";
elementToDrag.style.top=(e.clientY-deltaY)+"px";
//這兒就是改變現(xiàn)在正在作用的div的left和top屬性。
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);
}
//這個函數(shù)是用來移除偵聽器,比較簡單,就不詳細說了。
if (!e) e=window.event;
if(e.stopPropagation) e.stopPropagation();
else e.cancelBubble=true;
}
}
腳本之家 編輯注:如果不能正常運行 注意字符的替換,因為好多網(wǎng)站為了安裝都將字符轉換成了中文下的標點符號。本站也盡量的替換。

JavaScript技術javascript 可以拖動的DIV(二),轉載需保留來源!

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

主站蜘蛛池模板: 柏欣彤12点以后跳的广场舞| 宋学士濂文言文翻译| 15j401图集电子版免费查看| 喜欢小红帽的原因怎么写| 大石桥联盟| 学校要的建档立卡证明| 我的学生妈妈| free loop中文版歌词| 午夜魅影| 张学明| 免费播放高清完整版电影| 我的公公电影| 詹姆斯敦| 周星驰国产凌凌漆| 封神第一部| 欧洲18一19gay同志| 黄明昊身高| 山水微信头像| 泰星mike| rima horton| 心奇爆龙| 直播斯诺克直播间| 团结力量歌词大全图片| 在线爱爱视频| 栏目大全| 第一财经直播电视直播今日股市| 成年奶妈| 不纽扣的女孩| 电影《kiskisan》在线播放| 新有菜免费在线观看| 色在线播放| 包天笑| overwatch| 锦绣南歌免费看| 我的冠军男友在线看全集完整| 电影喜剧明星演员表| 黑暗森林 电影| 九狐| 成龙版杨家将电影免费播放| 哈利学前班| cctv6 节目表|