javascript 事件兼容

今天了解了js 的事件,以前寫代碼時并不會在意它的兼容問題,那么今天總結幾個關于事件的兼容寫法厦取。

1、js中經常用的就是點擊事件管搪,它在chrome 虾攻、火狐以及IE瀏覽器下的兼容寫法比較新奇,

document.onclik = function(e){

? ? ? ?var oEvent = e || event; ? ??

注意更鲁,不要將var e=e||event; 寫成 var e=event||e; 霎箍,這在FireFox下會提示錯誤,FireFox無法處理未聲明未賦值的變量event

? ? ? alert('x:'+oEvent.clientX + 'y:'+oEvent.clientY)

}

上述方式就是解決了兼容問題澡为, alert('x:'+e.clientX + 'y:'+e.clientY)? ? //兼容火狐

alert('x:'+event.clientX + 'y:'+event.clientY) ? ? ?//兼容chrome

2漂坏、鍵盤按下事件,它的兼容寫法:

document.onkeydown = function(e){

? ? ?if(e.keyCode){

? ? ? ? alert(e.keyCode)

? ? }else{

? ? ? ?alert(e.which)

? ? ?}

}

3媒至、阻止事件的冒泡顶别,我理解的就是父子級同時都綁定了點擊事件,如果執(zhí)行了其中一個事件拒啰,另外一個的事件也會被執(zhí)行驯绎,而且是從內往外執(zhí)行,也就是子級先執(zhí)行然后父級也被執(zhí)行谋旦,就造成了不必要的麻煩剩失,所以我們需要做的就是阻止事件的冒泡骗随。首先阻止事件的冒泡,暫時先寫兩個方式:

w3c 的方法是 e.stopPropagation()赴叹,

IE 則是使用 e.cancelBubble = true鸿染;

兼容寫法:

var e = e || window.event;? ? //這里一定寫成window.event,網上是說的是在IE(暫時僅限于8.0以下版本)下是行不通的,IE采用了一種非標準的方式乞巧,并不是將事件作為函數參數傳入涨椒,而是將事件作為window對象的event屬性:window.event、window.event.screenX...

if ( e && e.stopPropagation ){

? ? ?e.stopPropagation();

}else{

? ? ?e.cancelBubble = true;

}

4绽媒、取消默認 事件蚕冬,兼容寫法

e.preventDefault() ? ? ? // 火狐

?e.returnValue = false

var e = e||window.event;

if(e && e.preventDefault){

? ? ?e.preventDefault();

}else{

? ? ?e.returnValue = false;

}


5、事件的委托是辕,一般來說此類方法會涉及到循環(huán)囤热,用了事件委托之后,杜絕循環(huán)获三,執(zhí)行效率更高旁蔼,而且新創(chuàng)建的元素也可以執(zhí)行該事件。

事件的委托的兼容寫法:

oUl.onmouseover = function(e){

//為了兼容IE

? ? var oEvent = e||window.event;

? ? var target = oEvent.target|| oEvent.srcElement;

? ? if(target.nodeName.toLowerCase() == 'li'){

? ? ? ? target.style.background = 'red';

? ?}

}


6疙教、事件的捕獲棺聊,將其進行封裝:

function fun(ele,eve,handler,type){

? ? ?if(ele.attchEvent){

? ? ? ? ele.attachEvent("on"+eve,handler)

? ? ?}else{

? ? ? ? ele.addEventListener(eve,handler,type)

? ?}

}

ele:元素

eve:事件

handler:函數

type:值為false 或 true

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市贞谓,隨后出現的幾起案子限佩,更是在濱河造成了極大的恐慌,老刑警劉巖裸弦,帶你破解...
    沈念sama閱讀 211,042評論 6 490
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件祟同,死亡現場離奇詭異,居然都是意外死亡理疙,警方通過查閱死者的電腦和手機晕城,發(fā)現死者居然都...
    沈念sama閱讀 89,996評論 2 384
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來沪斟,“玉大人广辰,你說我怎么就攤上這事暇矫≈髦” “怎么了?”我有些...
    開封第一講書人閱讀 156,674評論 0 345
  • 文/不壞的土叔 我叫張陵李根,是天一觀的道長槽奕。 經常有香客問我,道長房轿,這世上最難降的妖魔是什么粤攒? 我笑而不...
    開封第一講書人閱讀 56,340評論 1 283
  • 正文 為了忘掉前任所森,我火速辦了婚禮,結果婚禮上夯接,老公的妹妹穿的比我還像新娘焕济。我一直安慰自己,他們只是感情好盔几,可當我...
    茶點故事閱讀 65,404評論 5 384
  • 文/花漫 我一把揭開白布晴弃。 她就那樣靜靜地躺著,像睡著了一般逊拍。 火紅的嫁衣襯著肌膚如雪上鞠。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,749評論 1 289
  • 那天芯丧,我揣著相機與錄音芍阎,去河邊找鬼。 笑死缨恒,一個胖子當著我的面吹牛谴咸,可吹牛的內容都是我干的。 我是一名探鬼主播骗露,決...
    沈念sama閱讀 38,902評論 3 405
  • 文/蒼蘭香墨 我猛地睜開眼寿冕,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了椒袍?” 一聲冷哼從身側響起驼唱,我...
    開封第一講書人閱讀 37,662評論 0 266
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎驹暑,沒想到半個月后玫恳,有當地人在樹林里發(fā)現了一具尸體,經...
    沈念sama閱讀 44,110評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡优俘,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 36,451評論 2 325
  • 正文 我和宋清朗相戀三年京办,在試婚紗的時候發(fā)現自己被綠了。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片帆焕。...
    茶點故事閱讀 38,577評論 1 340
  • 序言:一個原本活蹦亂跳的男人離奇死亡惭婿,死狀恐怖,靈堂內的尸體忽然破棺而出叶雹,到底是詐尸還是另有隱情财饥,我是刑警寧澤,帶...
    沈念sama閱讀 34,258評論 4 328
  • 正文 年R本政府宣布折晦,位于F島的核電站钥星,受9級特大地震影響,放射性物質發(fā)生泄漏满着。R本人自食惡果不足惜谦炒,卻給世界環(huán)境...
    茶點故事閱讀 39,848評論 3 312
  • 文/蒙蒙 一贯莺、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧宁改,春花似錦缕探、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,726評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至秽誊,卻和暖如春鲸沮,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背锅论。 一陣腳步聲響...
    開封第一講書人閱讀 31,952評論 1 264
  • 我被黑心中介騙來泰國打工讼溺, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人最易。 一個月前我還...
    沈念sama閱讀 46,271評論 2 360
  • 正文 我出身青樓怒坯,卻偏偏與公主長得像,于是被迫代替她去往敵國和親藻懒。 傳聞我的和親對象是個殘疾皇子剔猿,可洞房花燭夜當晚...
    茶點故事閱讀 43,452評論 2 348

推薦閱讀更多精彩內容