亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

JavaScript 函數(shù)惰性載入的實(shí)現(xiàn)及其優(yōu)點(diǎn)介紹

 更新時(shí)間:2013年08月12日 16:01:49   作者:  
惰性載入表示函數(shù)執(zhí)行的分支只會(huì)在函數(shù)第一次掉用的時(shí)候執(zhí)行,在第一次調(diào)用過程中,該函數(shù)會(huì)被覆蓋為另一個(gè)按照合適方式執(zhí)行的函數(shù),這樣任何對(duì)原函數(shù)的調(diào)用就不用再經(jīng)過執(zhí)行的分支了
最近看JavaScript高級(jí)程序設(shè)計(jì),大有收獲,接下來幾天寫一下讀書筆記。之前寫了一篇Ajax初步理解的隨筆,里面有個(gè)函數(shù)用來創(chuàng)建XmlHttpRequest對(duì)象,瀏覽器兼容性原因,寫出的代碼通過大量if判斷或者try,catch語句將函數(shù)引導(dǎo)到正確代碼處。
復(fù)制代碼 代碼如下:

<script type="text/javascript">
function createXHR(){
var xhr = null;
try {
// Firefox, Opera 8.0+, Safari,IE7+
xhr = new XMLHttpRequest();
}
catch (e) {
// Internet Explorer
try {
xhr = new ActiveXObject("Msxml2.XMLHTTP");
}
catch (e) {
try {
xhr = new ActiveXObject("Microsoft.XMLHTTP");
}
catch (e) {
xhr = null;
}
}
}
return xhr;
}
</script>

每次調(diào)用這個(gè)函數(shù)的時(shí)候,都要先進(jìn)行瀏覽器能力檢查,首先檢查瀏覽器是否支持內(nèi)置的XMLHyypRequest對(duì)象,如果不支持然后檢查各版本基于ActiveX的XMLHttpRequest,每次調(diào)用該函數(shù)都是這樣,其實(shí)當(dāng)?shù)谝淮螆?zhí)行完后,如果瀏覽器支持某個(gè)特定XMLHttpRequest對(duì)象,那么下次執(zhí)行的時(shí)候這種支持性并不會(huì)改變,沒必要再進(jìn)行一邊檢測(cè),即使只有一個(gè)if語句,執(zhí)行也肯定比沒有要慢,如果我們可以讓if語句不必每次執(zhí)行,那么就可以在頻繁調(diào)用的情況下提高執(zhí)行速度。解決方案就是稱之為惰性載入的技巧。

惰性載入

惰性載入表示函數(shù)執(zhí)行的分支只會(huì)在函數(shù)第一次掉用的時(shí)候執(zhí)行,在第一次調(diào)用過程中,該函數(shù)會(huì)被覆蓋為另一個(gè)按照合適方式執(zhí)行的函數(shù),這樣任何對(duì)原函數(shù)的調(diào)用就不用再經(jīng)過執(zhí)行的分支了。createXHR函數(shù)可以被改寫為這樣
復(fù)制代碼 代碼如下:

function createXHR(){
var xhr=null;
if(typeof XMLHttpRequest !='undefined'){
xhr = new XMLHttpRequest();
createXHR=function(){
return new XMLHttpRequest();
}
}else{
try {
xhr = new ActiveXObject("Msxml2.XMLHTTP");
createXHR=function(){
return new ActiveXObject("Msxml2.XMLHTTP");
}
}
catch (e) {
try {
xhr = new ActiveXObject("Microsoft.XMLHTTP");
createXHR=function(){
return new ActiveXObject("Microsoft.XMLHTTP");
}
}
catch (e) {
createXHR=function(){
return null;
}
}
}
}
return xhr;
}

在這個(gè)惰性載入的createXHR中第一次執(zhí)行的時(shí)候每個(gè)分支都會(huì)為createXHR重新賦值,覆蓋原函數(shù),返回xhr對(duì)象,而第二次執(zhí)行的時(shí)候就會(huì)直接調(diào)用重寫后的函數(shù),這樣就不必執(zhí)行每個(gè)分支重新做檢測(cè)了。

優(yōu)點(diǎn)

惰性載入函數(shù)有兩個(gè)主要優(yōu)點(diǎn),第一是顯而易見的效率問題,雖然在第一次執(zhí)行的時(shí)候函數(shù)會(huì)意味賦值而執(zhí)行的慢一些,但是后續(xù)的調(diào)用會(huì)因?yàn)楸苊獾闹貜?fù)檢測(cè)更快;第二個(gè)是要執(zhí)行的適當(dāng)代碼只有當(dāng)實(shí)際調(diào)用函數(shù)是才執(zhí)行,很多JavaScript庫在在加載的時(shí)候就根據(jù)瀏覽器不同而執(zhí)行很多分支,把所有東西實(shí)現(xiàn)設(shè)置好,而惰性載入函數(shù)將計(jì)算延遲,不影響初始腳本的執(zhí)行時(shí)間。

相關(guān)文章

  • js實(shí)現(xiàn)select下拉框菜單

    js實(shí)現(xiàn)select下拉框菜單

    這篇文章主要介紹了js實(shí)現(xiàn)select下拉框菜單的詳細(xì)代碼,感興趣的小伙伴們可以參考一下
    2015-12-12
  • 前端實(shí)現(xiàn)Word在線預(yù)覽功能詳解

    前端實(shí)現(xiàn)Word在線預(yù)覽功能詳解

    這篇文章主要給大家介紹了關(guān)于前端實(shí)現(xiàn)Word在線預(yù)覽功能的相關(guān)資料,工作中經(jīng)常有時(shí)會(huì)遇到需要給用戶創(chuàng)建word文檔并實(shí)現(xiàn)word文檔在線預(yù)覽的需求,需要的朋友可以參考下
    2023-09-09
  • 在bootstrap中實(shí)現(xiàn)輪播圖實(shí)例代碼

    在bootstrap中實(shí)現(xiàn)輪播圖實(shí)例代碼

    Bootstrap中輪播圖插件叫作Carousel ,下面通過本文給大家詳細(xì)介紹了bootstrop中實(shí)現(xiàn)輪播圖效果,需要的朋友參考下
    2017-06-06
  • php is_numberic函數(shù)造成的SQL注入漏洞

    php is_numberic函數(shù)造成的SQL注入漏洞

    這篇文章主要介紹了php is_numberic函數(shù)造成的SQL注入漏洞和解決辦法,需要的朋友可以參考下
    2014-03-03
  • js 遍歷對(duì)象的屬性的代碼

    js 遍歷對(duì)象的屬性的代碼

    js 遍歷對(duì)象的屬性的代碼,遍歷出對(duì)象的屬性可以用for in語句使用方法
    2011-12-12
  • 深入理解基于vue-cli的webpack打包優(yōu)化實(shí)踐及探索

    深入理解基于vue-cli的webpack打包優(yōu)化實(shí)踐及探索

    這篇文章主要介紹了基于vue-cli的webpack打包優(yōu)化實(shí)踐及探索,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-10-10
  • javascript 面向?qū)ο蠹夹g(shù)基礎(chǔ)教程

    javascript 面向?qū)ο蠹夹g(shù)基礎(chǔ)教程

    看了很多介紹javascript面向?qū)ο蠹夹g(shù)的文章,很暈.為什么?不是因?yàn)閷懙貌缓?而是因?yàn)樘願(yuàn)W.
    2009-12-12
  • cocos2dx骨骼動(dòng)畫Armature源碼剖析(一)

    cocos2dx骨骼動(dòng)畫Armature源碼剖析(一)

    cocos2dx中的骨骼動(dòng)畫在程序中使用非常方便,從編輯器(cocostudio或flash插件dragonBones)得到xml或json數(shù)據(jù),調(diào)用代碼就可以直接展示出動(dòng)畫效果,下面通過本篇文章給大家分享cocos2dx骨骼動(dòng)畫Armature源碼剖析,需要的朋友一起來學(xué)習(xí)吧。
    2015-09-09
  • TS中最常見的聲明合并(接口合并)

    TS中最常見的聲明合并(接口合并)

    這篇文章主要介紹了TS中最常見的聲明合并:接口合并,TS中的聲明合并,指的就是編譯器會(huì)針對(duì)同名的聲明合并為一個(gè)聲明,合并后的聲明會(huì)同時(shí)擁有原先兩個(gè)或多個(gè)聲明的特性,接口的合并也是一樣,它會(huì)將雙方的成員放到一個(gè)同名的接口里,更多詳細(xì)內(nèi)容請(qǐng)參考下面文章內(nèi)容

    2021-12-12
  • JS組件系列之Gojs組件 前端圖形化插件之利器

    JS組件系列之Gojs組件 前端圖形化插件之利器

    這篇文章主要介紹了Gojs組件,前端圖形化插件之利器的相關(guān)資料,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-11-11

最新評(píng)論