欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

為非IE瀏覽器添加mouseenter,mouseleave事件的實(shí)現(xiàn)代碼

 更新時(shí)間:2011年06月21日 00:59:19   作者:  
為非IE瀏覽器添加mouseenter,mouseleave事件的實(shí)現(xiàn)代碼,學(xué)習(xí)js的朋友可以參考下。

先了解幾個(gè)事件對(duì)象屬性

target 指事件源對(duì)象,點(diǎn)擊嵌套元素最里層的某元素,該元素就是target。IE6/7/8對(duì)應(yīng)的是srcElement。

currentTarget 指添加事件handler的元素本身,如el.addEventListener中el就是currentTarget。IE6/7/8沒(méi)有對(duì)應(yīng)屬性,可在handler內(nèi)使用this來(lái)替代如evt.currentTarget = this。

relativeTarget 指事件相關(guān)的元素,一般用在mouseover,mouseout事件中。IE6/7/8中對(duì)應(yīng)的是fromElement,toElement。
mouseentermouseleave IE9中仍然支持,另見 Greg Reimer 的博文 Goodbye mouseover, hello mouseenter
mouseenter與mouseover區(qū)別在于:在元素內(nèi)部移動(dòng)時(shí)mouseenter不會(huì)觸發(fā)。如下

復(fù)制代碼 代碼如下:

<!DOCTYPE HTML>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8"/>
<title>mouseerter與mouseover區(qū)別(IE下測(cè)試)</title>
</head>
<body>
<div id="result" style="position:absolute;right:100px;top:5px;width:250px;height:400px;border:2px solid gray;overflow:auto;">
</div>
<h3>1,鼠標(biāo)在div[id=parent1]內(nèi)部移動(dòng)時(shí)也會(huì)觸發(fā)mouseover事件</h3>
<div id="parent1" style="width:400px;border:1px solid gray;padding:5px;">
<div id="child11" style="width:100px;height:100px;background:gold;float:left;">Child11</div>
<div id="child12" style="width:100px;height:100px;background:gold;float:right;">Child12</div>
<div style="clear:both;"></div>
</div>
<br/>
<h3>2,鼠標(biāo)在div[id=parent2]內(nèi)部移動(dòng)時(shí)也不會(huì)觸發(fā)mouseenter事件</h3>
<div id="parent2" style="width:400px;border:1px solid gray;padding:5px;">
<div id="child21" style="width:100px;height:100px;background:gold;float:left;">Child21</div>
<div id="child22" style="width:100px;height:100px;background:gold;float:right;">Child22</div>
<div style="clear:both;"></div>
</div>
<script type="text/javascript">
function on(el,type,fn){
el.addEventListener ? el.addEventListener(type, fn, false) : el.attachEvent('on' + type, fn);
}
function $(id){
return document.getElementById(id);
}
var p1 = $('parent1'),
p2 = $('parent2');
function fn(e){
var d = document.createElement('div');
d.innerHTML = e.type;
$('result').appendChild(d);
}
on(p1,'mouseover',fn);
on(p2,'mouseenter',fn);
</script>
<body>
</html>

了解了這三個(gè)屬性的意義后,實(shí)現(xiàn)起來(lái)就簡(jiǎn)單了:
復(fù)制代碼 代碼如下:

E = function(){
function elContains(a, b){
try{
return a.contains ? a != b && a.contains(b) : !!(a.compareDocumentPosition(b) & 16);
}catch(e){}
}
function addEvt(el, type, fn){
function fun(e){
var a = e.currentTarget, b = e.relatedTarget;
if(!elContains(a, b) && a!=b){
fn.call(e.currentTarget,e);
}
}
if(el.addEventListener){
if(type=='mouseenter'){
el.addEventListener('mouseover', fun, false);
}else if(type=='mouseleave'){
el.addEventListener('mouseout', fun, false);
}else{
el.addEventListener(type, fn, false);
}
}else{
el.attachEvent('on' + type, fn);
}
}
return {addEvt:addEvt};
}();

測(cè)試代碼:

[Ctrl+A 全選 注:引入外部Js需再刷新一下頁(yè)面才能執(zhí)行]

相關(guān)文章

  • js Dom實(shí)現(xiàn)換膚效果

    js Dom實(shí)現(xiàn)換膚效果

    這篇文章主要為大家詳細(xì)介紹了js Dom實(shí)現(xiàn)換膚效果,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-10-10
  • js 數(shù)組 find,some,filter,reduce區(qū)別詳解

    js 數(shù)組 find,some,filter,reduce區(qū)別詳解

    區(qū)分清楚Array中filter、find、some、reduce這幾個(gè)方法的區(qū)別,根據(jù)它們的使用場(chǎng)景更好的應(yīng)用在日常編碼中。具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-06-06
  • 利用JavaScript的Map提升性能的方法詳解

    利用JavaScript的Map提升性能的方法詳解

    這篇文章主要介紹了利用JavaScript的Map提升性能的方法詳解,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2019-08-08
  • js學(xué)習(xí)心得_一個(gè)簡(jiǎn)單的動(dòng)畫庫(kù)封裝tween.js

    js學(xué)習(xí)心得_一個(gè)簡(jiǎn)單的動(dòng)畫庫(kù)封裝tween.js

    下面小編就為大家?guī)?lái)一篇js學(xué)習(xí)心得_一個(gè)簡(jiǎn)單的動(dòng)畫庫(kù)封裝tween.js。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2017-07-07
  • js 遞歸json樹實(shí)現(xiàn)根據(jù)子id查父id的方法分析

    js 遞歸json樹實(shí)現(xiàn)根據(jù)子id查父id的方法分析

    這篇文章主要介紹了js 遞歸json樹實(shí)現(xiàn)根據(jù)子id查父id的方法,結(jié)合實(shí)例形式分析了JavaScript遞歸遍歷json進(jìn)行數(shù)據(jù)查詢的相關(guān)操作技巧,需要的朋友可以參考下
    2019-11-11
  • js改變鼠標(biāo)的形狀和樣式的方法

    js改變鼠標(biāo)的形狀和樣式的方法

    常用的改變鼠標(biāo)樣式的方法:如果你想鼠標(biāo)移動(dòng)到某個(gè)元素上改變鼠標(biāo)樣式 就在這個(gè)元素的樣式里加上 cursor:(你想改的樣式)
    2014-03-03
  • 詳解js中常規(guī)日期格式處理、月歷渲染和倒計(jì)時(shí)函數(shù)

    詳解js中常規(guī)日期格式處理、月歷渲染和倒計(jì)時(shí)函數(shù)

    大家在日常開發(fā)的時(shí)候經(jīng)常要用到日期格式的處理,下面這篇文章主要給大家介紹了js中常規(guī)日期格式處理、月歷渲染及倒計(jì)時(shí)函數(shù),有需要的朋友可以參考借鑒,下面來(lái)一起看看吧。
    2016-12-12
  • 完美兼容多瀏覽器的js判斷圖片路徑代碼匯總

    完美兼容多瀏覽器的js判斷圖片路徑代碼匯總

    本文給大家匯總分享了幾種使用javascript實(shí)現(xiàn)判斷圖片路徑是否存在的代碼,都是平時(shí)項(xiàng)目中用到過(guò)的,這里總結(jié)一下,有需要的小伙伴可以參考下。
    2015-04-04
  • 微信小程序?qū)D片進(jìn)行canvas壓縮的方法示例詳解

    微信小程序?qū)D片進(jìn)行canvas壓縮的方法示例詳解

    這篇文章主要給大家介紹了關(guān)于微信小程序?qū)D片進(jìn)行canvas壓縮的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2020-11-11
  • 小程序中設(shè)置緩存過(guò)期的實(shí)現(xiàn)方法

    小程序中設(shè)置緩存過(guò)期的實(shí)現(xiàn)方法

    這篇文章主要介紹了小程序中設(shè)置緩存過(guò)期的實(shí)現(xiàn)方法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2020-01-01

最新評(píng)論