欧美成人精品手机在线观看_69视频国产_动漫精品第一页_日韩中文字幕网 - 日本欧美一区二区

LOGO OA教程 ERP教程 模切知識交流 PMS教程 CRM教程 開發文檔 其他文檔  
 
網站管理員

JS技巧:JavaScript獲取事件對象的注意事項

admin
2010年8月17日 23:17 本文熱度 3915

平時我們獲取事件對象一般寫法如下:


function getEvent(event) {    return event || window.event  // IE:window.event}如果沒有參數,也可寫成(非IE :事件對象會自動傳遞給對應的事件處理函數,且為第一個參數):


function getEvent() {    return arguments[0] || window.event // IE:window.event}這樣的寫法在除 Firefox(測試版本:3.0.12,下同) 外的瀏覽器上運行都不會有問題,但 Firefox 為什么例外呢?讓我們這樣一種情形:


<button id="btn" onclick="foo()">按鈕</button><script>function foo(){   var e =  getEvent();   alert(e);}</script>運行結果在 Firefox 中是 undefined,為什么呢?


在 Firefox 中調用其實是這樣的,先調用執行的是:


function foo(){   var e =  getEvent();   alert(e);}然后調用執行的是:


function onclick(
           
    $False$
     event) {    foo();}會發現在 Firefox 下 onclick="foo()" 中的 foo() 無法自動傳入事件對象參數,而默認傳遞給了系統生成的 onclick 函數,那本例我們可以通過 getEvent.caller.caller.arguments[0] 獲得事件對象。


因此,我們的 getEvent 可以優化成(參照 yui_2.7.0b 中的 event/event-debug.js 中 getEvent 方法):


function getEvent(event) {        var ev = event || window.event;        if (!ev) {                var c = this.getEvent.caller;                while (c) {                        ev = c.arguments[0];            if (ev && (Event == ev.constructor ||
           
   
     MouseEvent  == ev.constructor)) { //懌飛注:YUI 源碼 BUG,ev.constructor 也可能是 MouseEvent,不一定是 Event                break;            }            c = c.caller;                }        }        return ev;}當然還有一個很簡單的解決方法,就是手動將參數傳遞給 onclick="foo()":


<button id="btn" onclick="foo(event)">按鈕</button>


該文章在 2010/8/17 23:17:54 編輯過
關鍵字查詢
相關文章
正在查詢...
點晴ERP是一款針對中小制造業的專業生產管理軟件系統,系統成熟度和易用性得到了國內大量中小企業的青睞。
點晴PMS碼頭管理系統主要針對港口碼頭集裝箱與散貨日常運作、調度、堆場、車隊、財務費用、相關報表等業務管理,結合碼頭的業務特點,圍繞調度、堆場作業而開發的。集技術的先進性、管理的有效性于一體,是物流碼頭及其他港口類企業的高效ERP管理信息系統。
點晴WMS倉儲管理系統提供了貨物產品管理,銷售管理,采購管理,倉儲管理,倉庫管理,保質期管理,貨位管理,庫位管理,生產管理,WMS管理系統,標簽打印,條形碼,二維碼管理,批號管理軟件。
點晴免費OA是一款軟件和通用服務都免費,不限功能、不限時間、不限用戶的免費OA協同辦公管理系統。
Copyright 2010-2025 ClickSun All Rights Reserved