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

Javascript 瀏覽器事件小結(jié)

 更新時間:2010年02月13日 10:06:52   作者:  
Javascript中的事件都是與對象相關(guān)聯(lián)的,而不是語言本身所有,當Javascript在瀏覽器中運行的時候,事件與每個瀏覽器實現(xiàn)的DOM模型有關(guān)。
事件本身相當直觀,常用的有:
事件 描述
abort 圖片被阻止而不能加載
blur,focus 失去焦點,獲得焦點
change 適用于表單元素,當元素使其焦點的時候判斷是否發(fā)生改變
click,dblclick 單擊,雙擊
keydown,keyup,keypress 按下鍵,鍵離開,按下鍵的時候觸發(fā),注意keypress只對數(shù)字字母鍵有效
load 加載圖片或者頁面的時候
mousedown,mouseup 按下鍵,放開鍵
mouseover,mouseout over是當鼠標進入的時候出發(fā),out是離開的時候觸發(fā)
mousemove 鼠標移動
reset,submit 重置和提交表單

以上僅僅是常用的事件的列表,完整具體的列表可以查找相關(guān)手冊。

1. 0級DOM上的事件處理
0級DOM上的事件處理方法是比較早的,目前也廣泛應(yīng)用,從IE4.0開始就支持這類方法。

1.1 事件注冊
下面主要介紹如何添加響應(yīng)事件,也就是為事件添加處理程序。

(1)內(nèi)聯(lián)注冊(inline registration)

這是最簡單的一種,將事件響應(yīng)程序作為html標簽的一個屬性來設(shè)置,如下例,可以是代碼,當然更多情況下是一個函數(shù)調(diào)用。事件的句柄一般就是事件的名稱加上前綴on。

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

這種方法很簡單,任何瀏覽器都支持,缺點是將Javascript代碼和HTML代碼混雜在一起,而且不能動態(tài)添加事件響應(yīng)程序,也不能添加多個響應(yīng)程序。

(2)傳統(tǒng)模式(traditional registration)

這種模式將事件作為對象的屬性進行添加。例如:

1.2 事件的參數(shù)(Event對象)
有些事件處理程序需要一些關(guān)于事件更多的信息,比如click事件發(fā)生的位置等。這些信息是通過事件參數(shù)傳給事件處理程序的。IE事件模型和W3C事件模型對此的實現(xiàn)是不同的。

IE把event對象作為window對象的一個屬性,而W3C把event對象作為處理程序的一個參數(shù)。下面以click事件為例,分別寫一個程序用于IE和支持W3C標準的瀏覽器。

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

這一段頁面代碼可以把click事件對象的所有屬性都展示出來。上面的例子是W3C的瀏覽器所用的方法,要在IE下使用,只要改成onclick=”IEClick()”.注意,W3CClick中的參數(shù)名,只能是event。打印出來的屬性很多,我分別用FF3.5,Chrome3,IE8(標準模式和兼容模式)運行,他們共有的屬性并不多,其實也就這些共有的屬性才有意義,他們是:

altKey,shiftKey,ctrlKey:是否按下alt,shift,ctrl鍵

clientX,clientY:客戶區(qū)坐標(瀏覽器窗口),screenX,screenY:屏幕區(qū)坐標

type:事件類型

雖然事件的參數(shù)的傳遞方式有點不同,但是對于寫跨瀏覽器的代碼也沒有造成太多的麻煩,只需要在函數(shù)一開始判斷下window.event有沒有定義即可。
復(fù)制代碼 代碼如下:

function BothClick(args) {
var evnt = window.event ? window.event : args;
alert(evnt.clientX);
}

注冊句柄為:<div id="adiv" onclick="BothClick(event)" >a</div>如果采用第二種方式注冊句柄,則不需要什么特別處理。

1.3 事件的浮升
頁面上的對象通常是重疊的,比如一個div中可以包括若干div或者其他元素。當某一事件觸發(fā)的時候,同時有多個元素受影響,并且它們都有相應(yīng)的事件處理程序,那么這些事件處理程序執(zhí)行哪些?以何種順序執(zhí)行?這就是本節(jié)要討論的問題。通常情況下,一個事件被多個句柄捕獲的情形并不多見。先看一個例子(CSS省略):

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

在body,外層div和內(nèi)層div都響應(yīng)了click事件,結(jié)果如下:
image 
可見,事件是由內(nèi)向外層的元素依次觸發(fā)的。(一般教材上的說法是向上浮升,bubbling,我覺得這個向上是有歧義的,我一開始就誤認為內(nèi)層的元素是上面的,因為它能覆蓋外層的元素)用0級DOM注冊的事件,它的浮升方法無論是IE還是W3C都是統(tǒng)一的。

1.4 浮升的取消
有時候我們需要在響應(yīng)了一個事件之后,就不需要外層的元素再響應(yīng)了,可以取消事件的浮升。取消的方法IE和W3C是不一致的。IE是通過設(shè)置事件對象的cancelBubble屬性來實現(xiàn),W3C則是調(diào)用事件對象的stopPropagation方法。

例如上面的例子改為:
復(fù)制代碼 代碼如下:

function inner_click(arg){
var evnt=window.event?window.event:arg;
var dis=document.getElementById("res");
dis.innerHTML+="Inner Click <br/>";
if(evnt.stopPropagation){
evnt.stopPropagation();
}else{
evnt.cancelBubble=true;
}
}<div id="innerdiv" onclick="inner_click(event)" >

其他不變,這樣就只能看到一行輸出。

1.5 事件處理函數(shù)中的this
這個this指向的是觸發(fā)事件的對象。

下面介紹2級DOM的事件句柄。這種方式是比較新的方式,它不依賴于任何特定的事件句柄屬性。W3C規(guī)定的方式是

object.addEventListener(‘event',function,boolean)

第一個參數(shù)是事件名,第二個是事件響應(yīng)函數(shù),第三個變量如果是true,則事件函數(shù)在事件冒泡階段被觸發(fā),否則是在事件的捕獲階段被觸發(fā)。W3C規(guī)定事件的發(fā)生有兩個階段,首先是捕獲,即事件以此從最外層層的元素向內(nèi)層傳遞,相應(yīng)的事件處理函數(shù)被依次觸發(fā),然后是冒泡階段,事件從最內(nèi)層的元素向外層傳遞。 看一個例子:

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

點擊灰色框,會依次彈出body true,div true,div false,body false. 很遺憾,IE不支持這種方式,最新的IE8也不支持。不過IE也有類似的注冊事件的方法,名字是attachEvent.不過這個方法沒有第三個參數(shù),它支持冒泡階段的事件響應(yīng)。attachEvent函數(shù)傳遞事件參數(shù)的時候是和W3C一致的,也是通過event參數(shù)傳遞,但是,其函數(shù)內(nèi)部的this指向的不是觸發(fā)事件對象,而永遠指向window。在event對象中有一個屬性指向觸發(fā)該事件的對象,W3C中是target,IE中是srcElement, 在符合W3C規(guī)范的瀏覽器中,事件處理函數(shù)中的this和event.target指向的是同一個對象。下面的程序展示了一個IE和W3C兼容的事件處理程序:

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

事件處理程序中W3C和IE還有諸多不一致之處,十分麻煩。好在大多都有較好的解決方案。更多信息請參考http://www.quirksmode.org/js/events_events.html

相關(guān)文章

  • js實現(xiàn)帶簡單彈性運動的導(dǎo)航條

    js實現(xiàn)帶簡單彈性運動的導(dǎo)航條

    本篇文章主要分享了js實現(xiàn)帶簡單彈性運動導(dǎo)航條的示例代碼,具有很好的參考價值,下面跟著小編一起來看下吧
    2017-02-02
  • JS實現(xiàn)超簡單的仿QQ折疊菜單效果

    JS實現(xiàn)超簡單的仿QQ折疊菜單效果

    這篇文章主要介紹了JS實現(xiàn)超簡單的仿QQ折疊菜單效果,可實現(xiàn)鼠標滑過列表展開的QQ折疊菜單效果,非常簡單實用,需要的朋友可以參考下
    2015-09-09
  • uniapp基礎(chǔ)知識點掌握以及面試題整理

    uniapp基礎(chǔ)知識點掌握以及面試題整理

    uni-app是一個使用vue.js開發(fā)所有前端應(yīng)用的框架,開發(fā)者編寫一套代碼,下面這篇文章主要給大家介紹了關(guān)于uniapp基礎(chǔ)知識點掌握以及面試題整理的相關(guān)資料,需要的朋友可以參考下
    2023-02-02
  • ES7中利用Await減少回調(diào)嵌套的方法詳解

    ES7中利用Await減少回調(diào)嵌套的方法詳解

    大家都知道在ES7中有了標準的回調(diào)函數(shù)嵌套的解決方案,新增了 async/await兩個關(guān)鍵詞,所以這篇文章主要給大家介紹了關(guān)于Javascript中如何利用Await減少回調(diào)嵌套的相關(guān)資料,需要的朋友可以參考借鑒,下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧。
    2017-11-11
  • 非常漂亮的JS+CSS圖片幻燈切換特效

    非常漂亮的JS+CSS圖片幻燈切換特效

    放在你的首頁比較不錯,寬屏圖片格式,每張圖片平滑飛入切換,鼠標放上自動切換,和FLASH的平滑效果差不多,喜歡的朋友可以收藏下
    2013-11-11
  • js,jq,css多方面實現(xiàn)簡易下拉菜單功能

    js,jq,css多方面實現(xiàn)簡易下拉菜單功能

    這篇文章主要介紹了js,jq,css多方面實現(xiàn)簡易下拉菜單功能,需要的朋友可以參考下
    2017-05-05
  • javascript操作excel生成報表全攻略

    javascript操作excel生成報表全攻略

    這篇文章主要介紹了如何使用javascript操作excel生成報表,需要的朋友可以參考下
    2014-05-05
  • js onmousewheel事件多次觸發(fā)問題解決方法

    js onmousewheel事件多次觸發(fā)問題解決方法

    做一個首屏和第二屏之間滾動鼠標滾輪就可以整平切換的效果,遇到了很多問題,下面是問題解決方法
    2014-10-10
  • 在小程序Canvas中使用measureText的方法示例

    在小程序Canvas中使用measureText的方法示例

    有時候我們在使用Canvas繪制一段文本時,會需要通過measureText()方法獲取文本的寬度,本文主要介紹了在小程序Canvas中使用measureText的方法示例,需要的朋友可以參考下
    2018-10-10
  • JavaScript delete 屬性的使用

    JavaScript delete 屬性的使用

    JavaScript對象數(shù)據(jù)結(jié)構(gòu)基本形式:{ key : value},其中key:value就為對象的一個屬性,key作為屬性名稱,value為屬性值,這值可以是任何JavaScript數(shù)據(jù)類型。
    2009-10-10

最新評論