国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

onmouseover和onmouseout的一些問題思考

2019-11-20 22:24:34
字體:
來源:轉載
供稿:網友
一個DIV層,當鼠標移進的時候會觸發onmouseover,移出的時候會觸發onmouseout。
 
很簡單的邏輯,這也是我們想要的!但隨之煩惱也就來了:onmouseover并不會只在移進時才觸發,onmouseout也不會只在移出時才觸發!鼠標在DIV里面移動時也會可能觸發onmouseover或onmouseout。
 
在上圖中,對于'A'來說:當鼠標進入'A'(路徑'1′)時那么就會觸發'A'的onmouseover事件;接著鼠標移動到'B'(路徑'2′),此時'A'會觸發onmouseout(先)和onmouseover(后)事件。

由此可見,如果HTML元素(‘A'層)內還有其他元素(‘B','C'層),當我們移動到這些內部的元素時就會觸發最外層(‘A'層)的onmouseout和onmouseover事件。

這兩個事件的觸發表現真的就是你想要的嗎?也許你需要一個只在移進時才觸發的,一個只在移出時才觸發的事件,不管其內部是否還有其他元素….

解決方案

在IE下確實有你需要的兩個這樣事件:onmouseenter 和 onmouseleave。但很不幸FF等其他瀏覽器并不支持,只好模擬實現:
復制代碼 代碼如下:

document.getElementById('...').onmouseover = function(e){
if( !e ) e = window.event;
var reltg = e.relatedTarget ? e.relatedTarget : e.fromElement;
while( reltg && reltg != this ) reltg = reltg.parentNode;
if( reltg != this ){
// 這里可以編寫 onmouseenter 事件的處理代碼
}
}
document.getElementById('...').onmouseout = function(e){
if( !e ) e = window.event;
var reltg = e.relatedTarget ? e.relatedTarget : e.toElement;
while( reltg && reltg != this ) reltg = reltg.parentNode;
if( reltg != this ){
// 這里可以編寫 onmouseleave 事件的處理代碼
}
}

備注:

W3C在mouseover和mouseout事件中添加了relatedTarget屬性

•在mouseover事件中,它表示鼠標來自哪個元素
•在mouseout事件中,它指向鼠標去往的那個元素
而Microsoft在mouseover和mouseout事件中添加了兩個屬性

•fromElement,在mouseover事件中表示鼠標來自哪個元素
•toElement,在mouseout事件中指向鼠標去往的那個元素
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 礼泉县| 白城市| 桃江县| 镇康县| 铜梁县| 宁陕县| 南江县| 平罗县| 鸡东县| 姜堰市| 河池市| 邵阳县| 武隆县| 双城市| 富锦市| 青海省| 玉树县| 莱阳市| 娄底市| 塔河县| 旺苍县| 扎兰屯市| 孙吴县| 贞丰县| 马龙县| 武功县| 莆田市| 岑溪市| 开远市| 文山县| 连平县| 广丰县| 东方市| 长宁县| 启东市| 梅州市| 临沧市| 保山市| 湘潭县| 宣汉县| 霞浦县|