成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

JavaScript 事件——“事件類型”中“HTML5事件”的注意要點(diǎn)

rozbo / 2906人閱讀

摘要:因?yàn)樵撌录儆谑髽?biāo)事件,所以其事件對象中包含與光標(biāo)位置有關(guān)的所有屬性。事件和屬性該事件在頁面顯示時(shí)觸發(fā),雖然這個(gè)事件的目標(biāo)是,但是必須將其事件處理程序添加到。事件該事件以便在的參數(shù)列表及中號后面的所有字符串發(fā)生變化時(shí)通知開發(fā)人員。

contextmenu事件

該事件用以表示何時(shí)應(yīng)該顯示上下文菜單,以便開發(fā)者取消默認(rèn)的上下文菜單,轉(zhuǎn)而提供自定義的菜單。

因?yàn)樵撌录儆谑髽?biāo)事件,所以其事件對象中包含與光標(biāo)位置有關(guān)的所有屬性。如:


    
    

chrome現(xiàn)在支持該事件,部分瀏覽器都支持。

beforeunload事件

該事件是為了讓開發(fā)者有可能在頁面卸載前阻止這一操作。event.returnValue設(shè)置的值是顯示給用戶的字符串(對于IE以及Firefox而言),同時(shí)作為函數(shù)的值返回(對safari和chrome而言),如:

window.addEventListener("beforeunload", function () {
    var message = "do you realy want to leave?";
    event.returnValue = message;
    return message;
}); //當(dāng)離開時(shí)會顯示信息和兩個(gè)按鈕;當(dāng)刷新時(shí)也會提示;
DOMContentLoaded事件

該事件在形成完整的DOM樹之后就會觸發(fā),不理會圖像、js文件、css文件等其他資源下載完畢。

readystatechange事件

IE提供的事件,支持該事件的每個(gè)對象都有一個(gè)readyState屬性,可能包含下列5個(gè)值中的一個(gè):

uninitialized(未初始化):對象存在但尚未初始化;

loading(正在加載):對象正在加載數(shù)據(jù);

loaded(加載完畢):對象加載數(shù)據(jù)完成;

interactive(交互):可以操作對象,但還沒有完全加載;

complete(完成):對象已經(jīng)加載完畢;

并非每個(gè)對象都會經(jīng)歷這些階段;值為interactive的readyState會在與DOMContentLoaded大致相同的時(shí)刻觸發(fā)readystatechange事件。事件的event對象不會提供任何信息。

switch (document.readyState) {
    case "loading":
        // 正在加載
        console.log("loading");
    case "interactive":
        // 交互階段 可以操作對象了
        var span = document.createElement("span");
        span.textContent = "A  element.";
        document.body.appendChild(span);
        console.log("The document has finished loading. We can now access the DOM elements.")
    case "complete":
        // 完成階段 完全加載完畢了
        console.log("The first CSS rule is: " + document.styleSheets[0].cssRules[0].cssText);
        console.log("The page is fully loaded.")
        break;
}

如:

document.addEventListener("readystatechange", function () {
    if (document.readyState == "loading") {
        var newP = document.createElement("p");
        newP.appendChild(document.createTextNode("data1"));
        document.body.appendChild(newP);
    }
    if (document.readyState == "interactive") {
        var newP = document.createElement("p");
        newP.appendChild(document.createTextNode("data2"));
        document.body.appendChild(newP);
    }
});
//上述代碼的第一段并沒有在document.body下創(chuàng)建一個(gè)新的p,因?yàn)閞eadyState為loading的時(shí)候并不能操作對象;

又如:

document.addEventListener("readystatechange", function () {
    if (document.readyState == "loading") {
        var newP = document.createElement("p");
        newP.appendChild(document.createTextNode("data1"));
        document.body.appendChild(newP);

        console.log(document.styleSheets[0].cssRules[0].cssText); //無效,因?yàn)閘oading的時(shí)候,對象沒有加載完全加載完畢(complete)
    }
    if (document.readyState == "interactive") {
        var newP = document.createElement("p");
        newP.appendChild(document.createTextNode("data2"));
        document.body.appendChild(newP);

        console.log(document.styleSheets[0].cssRules[0].cssText); //可能有效,外部資源少的情況下完成階段很可能在交互階段之前出現(xiàn);而在外部資源較多的情況下完成階段很可能在交互階段之后出現(xiàn)。
    }
    
});
//上述代碼的第一段并沒有在document.body下創(chuàng)建一個(gè)新的p,因?yàn)閞eadyState為loading的時(shí)候并不能操作對象;

交互階段可能早于或晚于完成階段出現(xiàn),無法確保順序。在包含較多外部資源的頁面中,交互階段更有可能出現(xiàn)的早;在包含較少外部資源的頁面中,完成階段更有可能出現(xiàn)的早。因此,為了盡可能搶到先機(jī),有必要同時(shí)檢測交互和完成階段,如:

document.addEventListener("readystatechange", function ready () {
    if (document.readyState == "interactive" || document.readyState == "complete") {
        document.removeEventListener("readystatechange", ready;
        console.log("Content loaded");
    }
});

見《js高級程序設(shè)計(jì)》第十三章事件類型html5事件中readystatechange事件,第二版391頁

這樣編寫的代碼,可以達(dá)到與使用DOMContentLoaded十分接近的效果。

另外,關(guān)于script元素和link元素的加載情況參考:

就緒狀態(tài)(readystatechange)事件

pageshowpagehide事件

“往返緩存(back-forward cache或bfcache)”——可以在用戶使用瀏覽器的“前進(jìn)”、“后退”按鈕時(shí)加快頁面的轉(zhuǎn)換速度。如果頁面位于bgcache中,那么再次打開該頁面時(shí)就不會觸發(fā)load事件。

pageshow事件和event.persisted屬性

該事件在頁面顯示時(shí)觸發(fā),雖然這個(gè)事件的目標(biāo)是document,但是必須將其事件處理程序添加到window。如:

window.addEventListener("pageshow", function(event) {
    console.log("pageshow:");
    console.log(event); //PageTransitionEvent
});

屬性是一個(gè)布爾值,如果頁面保存在了bfcache中,則這個(gè)屬性的值為true;否則為false。

hashchange事件

該事件以便在URL的參數(shù)列表(及URL中“#”號后面的所有字符串)發(fā)生變化時(shí)通知開發(fā)人員。必須把這個(gè)事件的事件處理程序添加給window對象。event對象中有兩個(gè)屬性:oldURLnewURL。這兩個(gè)屬性分別保存著參數(shù)列表變化前后的完整URL:

window.addEventListener("hashchange", function () {
    console.log("Old URL:" + event.oldURL + "
New URL: " + event.newURL);
});

檢測:

如果IE8是在IE7文檔模式下運(yùn)行,即使功能無效也會返回true:

var isSupported = ("onhashchange" in window) && (document.documentMode === undefined || document.documentMode > 7);

文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/91609.html

相關(guān)文章

  • JavaScript DOM 事件初探

    摘要:級事件規(guī)定的事件流包括三個(gè)階段事件捕獲階段處于目標(biāo)階段和事件冒泡階段。對象只存在于事件處理程序執(zhí)行期間,一旦執(zhí)行完畢,立即被銷毀。焦點(diǎn)事件焦點(diǎn)事件會在頁面元素獲得或失去焦點(diǎn)時(shí)觸發(fā)。 JavaScript DOM 事件初探 原文鏈接 事件,就是文檔或?yàn)g覽器窗口中發(fā)生的一些特定的交互瞬間,比如單擊、雙擊、鼠標(biāo)懸浮等。 事件流 事件流描述的是從頁面中接收事件的順序,或者說是事件在頁面中傳播...

    Moxmi 評論0 收藏0
  • JavaScript 事件——“事件類型“UI事件注意要點(diǎn)

    摘要:事件這個(gè)事件在文檔被完全卸載后觸發(fā)。事件當(dāng)瀏覽器窗口被調(diào)整到一個(gè)新的高度或?qū)挾?,就會觸發(fā)該事件。事件該事件雖然在對象上發(fā)生的,但實(shí)際表示的是頁面中響應(yīng)元素的變化。事件關(guān)于等事件以后再討論事件關(guān)于等事件以后再討論事件關(guān)于等事件以后再討論 DOM3級事件規(guī)定了一下幾類事件 UI事件,當(dāng)用戶與頁面上的元素交互時(shí)除法; 焦點(diǎn)事件,元素獲得或失去焦點(diǎn); 鼠標(biāo)事件,通過鼠標(biāo)在頁面上執(zhí)行操作; 滾...

    sushi 評論0 收藏0
  • JavaScript 事件——“模擬事件注意要點(diǎn)

    DOM中的事件模擬 三個(gè)步驟: 首先通過document.createEvent()方法創(chuàng)建event對象,接收一個(gè)參數(shù),即表示要創(chuàng)建的事件類型的字符串: UIEvents(DOM3中的UIEvent)鼠標(biāo)和鍵盤事件; MouseEvents(DOM3中的MouseEvent)鼠標(biāo)事件; MutationEvents(DOM3中的MutationEvent)變動事件; HTMLEvents(沒有...

    BakerJ 評論0 收藏0
  • JavaScript 事件——“事件類型“復(fù)合事件”和“變動事件注意要點(diǎn)

    摘要:復(fù)合事件復(fù)合事件是級事件中心添加的一類事件,用于處理的輸入序列。這個(gè)事件在之后觸發(fā)在一個(gè)節(jié)點(diǎn)被直接從文檔中移除,或通過子樹間接從文檔中移除之前觸發(fā)。最后一個(gè)觸發(fā)的事件是,觸發(fā)于新插入節(jié)點(diǎn)的父節(jié)點(diǎn)。 復(fù)合事件 復(fù)合事件是DOM3級事件中心添加的一類事件,用于處理IME的輸入序列。 compositionstart、compositionupdate、compositionend 復(fù)合...

    Meathill 評論0 收藏0

發(fā)表評論

0條評論

最新活動
閱讀需要支付1元查看
<