跨平臺(tái)(格式化)event
來(lái)源:易賢網(wǎng) 閱讀:916 次 日期:2014-08-15 17:22:48
溫馨提示:易賢網(wǎng)小編為您整理了“跨平臺(tái)(格式化)event”,方便廣大網(wǎng)友查閱!

在前面一篇文章寫(xiě)了javascript事件對(duì)象,Dom和IE的對(duì)象在不同瀏覽器下是不同的,如果要跨平臺(tái)使用則要格式化event或者是叫補(bǔ)充不同的屬性和方法.為了更簡(jiǎn)單些,直接講window IE下的屬性或者方法進(jìn)行調(diào)整,使其擁有Dom的方法或?qū)傩?IE下沒(méi)有Dom的一些方法或者屬性,則通過(guò)IE的方法或者屬性來(lái)轉(zhuǎn)換或者定義為Dom的屬性

直接上代碼,在代碼中解釋

<script language="javascript">

var foraspcn = new Object;//這個(gè)不用解釋了,上一篇溫江對(duì)這個(gè)已經(jīng)詳細(xì)說(shuō)明了.

foraspcn.format_event = function(oEvent)//這里的oEvent 是傳過(guò)來(lái)的window的屬性event,或者是Dom的唯一函數(shù)<網(wǎng)站制作學(xué)習(xí)網(wǎng)>

{

var sUserAgent = navigator.userAgent;

var isIE = sUserAgent.indexOf("compatible")>-1 &&sUserAgent.indexOf("MSIE")>-1&&!sUserAgent.indexOf("Opera")>-1;

var isWin = (navigator.platform == "Win32") || (navigator.platform == "Windows");

if(isIE && isWin)

{oEvent.charCode = (oEvent.type == "keypress")?oEvent.keyCode:0;

//IE中的字符代碼是在keypress事件發(fā)生時(shí)包含到keyCode屬性中,如果要?jiǎng)?chuàng)建charCode則直接返回keyCode否則返回0

oEvent.eventPhase = 2;

//設(shè)置eventPhase 為2始終是冒泡階段

oEvent.isChar = (oEvet.charCode > 0);

//如果判斷是不是字符時(shí),IE下判斷charCode是否大于0,如果大于則表示是,返回真.反之假

oEvent.pageX = oEvent.clinetX +document.body.scrollLeft;

oEvent.pageY = oEvent.clinetY +document.body.scrollTop;

//Dom中鼠標(biāo)的位置在ie中獲取鼠標(biāo)的位置clinet(不包含滾動(dòng)條),再加上滾動(dòng)條的位移<網(wǎng)站制作學(xué)習(xí)網(wǎng)>

oEvent.preventDefault = function(){this.returnvalue = false;}

//直接定義阻止默認(rèn)事件為false

if(oEvent.type == "mouseout")

{

oEvent.relatedTaget = oEvent.toElement;

}else if(oEvent.type == "mouseover")

{

oEvent.relatedTarget = oEvent.fromElement;

}

//通過(guò)不同的事件來(lái)定義ralatedTarget,看IE的屬性中是不一樣的.

oEvent.stopPropagation = function(){this.cancelBubble = true;}

//直接設(shè)置stopPropagation 為IE中的cancelbubble = true;

oEvent.target = oEvent.srcElement;

oEvent.time = (new Date().getTime());

}

return oEvent;

}

//調(diào)用格式化event//<網(wǎng)站制作學(xué)習(xí)網(wǎng)>

foraspcn.get_event = function(){

if(window.event)

{

return this.format_event(window.event);//如果是IE則進(jìn)行格式化window.event

}

else

{

return foraspcn.format_event.caller.arguments[0];//如果不是IE則調(diào)用調(diào)用函數(shù)的第一個(gè)參數(shù)即Dom的event

}

}

</script>

學(xué)習(xí)中........

更多信息請(qǐng)查看IT技術(shù)專(zhuān)欄

更多信息請(qǐng)查看腳本欄目
易賢網(wǎng)手機(jī)網(wǎng)站地址:跨平臺(tái)(格式化)event
由于各方面情況的不斷調(diào)整與變化,易賢網(wǎng)提供的所有考試信息和咨詢(xún)回復(fù)僅供參考,敬請(qǐng)考生以權(quán)威部門(mén)公布的正式信息和咨詢(xún)?yōu)闇?zhǔn)!

2025國(guó)考·省考課程試聽(tīng)報(bào)名

  • 報(bào)班類(lèi)型
  • 姓名
  • 手機(jī)號(hào)
  • 驗(yàn)證碼
關(guān)于我們 | 聯(lián)系我們 | 人才招聘 | 網(wǎng)站聲明 | 網(wǎng)站幫助 | 非正式的簡(jiǎn)要咨詢(xún) | 簡(jiǎn)要咨詢(xún)須知 | 新媒體/短視頻平臺(tái) | 手機(jī)站點(diǎn) | 投訴建議
工業(yè)和信息化部備案號(hào):滇ICP備2023014141號(hào)-1 云南省教育廳備案號(hào):云教ICP備0901021 滇公網(wǎng)安備53010202001879號(hào) 人力資源服務(wù)許可證:(云)人服證字(2023)第0102001523號(hào)
云南網(wǎng)警備案專(zhuān)用圖標(biāo)
聯(lián)系電話(huà):0871-65099533/13759567129 獲取招聘考試信息及咨詢(xún)關(guān)注公眾號(hào):hfpxwx
咨詢(xún)QQ:1093837350(9:00—18:00)版權(quán)所有:易賢網(wǎng)
云南網(wǎng)警報(bào)警專(zhuān)用圖標(biāo)