JavaScript 函數(shù)惰性載入的實現(xiàn)及其優(yōu)點介紹
更新時間:2013年08月12日 16:01:49 作者:
惰性載入表示函數(shù)執(zhí)行的分支只會在函數(shù)第一次掉用的時候執(zhí)行,在第一次調(diào)用過程中,該函數(shù)會被覆蓋為另一個按照合適方式執(zhí)行的函數(shù),這樣任何對原函數(shù)的調(diào)用就不用再經(jīng)過執(zhí)行的分支了
最近看JavaScript高級程序設(shè)計,大有收獲,接下來幾天寫一下讀書筆記。之前寫了一篇Ajax初步理解的隨筆,里面有個函數(shù)用來創(chuàng)建XmlHttpRequest對象,瀏覽器兼容性原因,寫出的代碼通過大量if判斷或者try,catch語句將函數(shù)引導(dǎo)到正確代碼處。
<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)用這個函數(shù)的時候,都要先進行瀏覽器能力檢查,首先檢查瀏覽器是否支持內(nèi)置的XMLHyypRequest對象,如果不支持然后檢查各版本基于ActiveX的XMLHttpRequest,每次調(diào)用該函數(shù)都是這樣,其實當(dāng)?shù)谝淮螆?zhí)行完后,如果瀏覽器支持某個特定XMLHttpRequest對象,那么下次執(zhí)行的時候這種支持性并不會改變,沒必要再進行一邊檢測,即使只有一個if語句,執(zhí)行也肯定比沒有要慢,如果我們可以讓if語句不必每次執(zhí)行,那么就可以在頻繁調(diào)用的情況下提高執(zhí)行速度。解決方案就是稱之為惰性載入的技巧。
惰性載入
惰性載入表示函數(shù)執(zhí)行的分支只會在函數(shù)第一次掉用的時候執(zhí)行,在第一次調(diào)用過程中,該函數(shù)會被覆蓋為另一個按照合適方式執(zhí)行的函數(shù),這樣任何對原函數(shù)的調(diào)用就不用再經(jīng)過執(zhí)行的分支了。createXHR函數(shù)可以被改寫為這樣
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;
}
在這個惰性載入的createXHR中第一次執(zhí)行的時候每個分支都會為createXHR重新賦值,覆蓋原函數(shù),返回xhr對象,而第二次執(zhí)行的時候就會直接調(diào)用重寫后的函數(shù),這樣就不必執(zhí)行每個分支重新做檢測了。
優(yōu)點
惰性載入函數(shù)有兩個主要優(yōu)點,第一是顯而易見的效率問題,雖然在第一次執(zhí)行的時候函數(shù)會意味賦值而執(zhí)行的慢一些,但是后續(xù)的調(diào)用會因為避免的重復(fù)檢測更快;第二個是要執(zhí)行的適當(dāng)代碼只有當(dāng)實際調(diào)用函數(shù)是才執(zhí)行,很多JavaScript庫在在加載的時候就根據(jù)瀏覽器不同而執(zhí)行很多分支,把所有東西實現(xiàn)設(shè)置好,而惰性載入函數(shù)將計算延遲,不影響初始腳本的執(zhí)行時間。
復(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)用這個函數(shù)的時候,都要先進行瀏覽器能力檢查,首先檢查瀏覽器是否支持內(nèi)置的XMLHyypRequest對象,如果不支持然后檢查各版本基于ActiveX的XMLHttpRequest,每次調(diào)用該函數(shù)都是這樣,其實當(dāng)?shù)谝淮螆?zhí)行完后,如果瀏覽器支持某個特定XMLHttpRequest對象,那么下次執(zhí)行的時候這種支持性并不會改變,沒必要再進行一邊檢測,即使只有一個if語句,執(zhí)行也肯定比沒有要慢,如果我們可以讓if語句不必每次執(zhí)行,那么就可以在頻繁調(diào)用的情況下提高執(zhí)行速度。解決方案就是稱之為惰性載入的技巧。
惰性載入
惰性載入表示函數(shù)執(zhí)行的分支只會在函數(shù)第一次掉用的時候執(zhí)行,在第一次調(diào)用過程中,該函數(shù)會被覆蓋為另一個按照合適方式執(zhí)行的函數(shù),這樣任何對原函數(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;
}
在這個惰性載入的createXHR中第一次執(zhí)行的時候每個分支都會為createXHR重新賦值,覆蓋原函數(shù),返回xhr對象,而第二次執(zhí)行的時候就會直接調(diào)用重寫后的函數(shù),這樣就不必執(zhí)行每個分支重新做檢測了。
優(yōu)點
惰性載入函數(shù)有兩個主要優(yōu)點,第一是顯而易見的效率問題,雖然在第一次執(zhí)行的時候函數(shù)會意味賦值而執(zhí)行的慢一些,但是后續(xù)的調(diào)用會因為避免的重復(fù)檢測更快;第二個是要執(zhí)行的適當(dāng)代碼只有當(dāng)實際調(diào)用函數(shù)是才執(zhí)行,很多JavaScript庫在在加載的時候就根據(jù)瀏覽器不同而執(zhí)行很多分支,把所有東西實現(xiàn)設(shè)置好,而惰性載入函數(shù)將計算延遲,不影響初始腳本的執(zhí)行時間。
相關(guān)文章
php is_numberic函數(shù)造成的SQL注入漏洞
這篇文章主要介紹了php is_numberic函數(shù)造成的SQL注入漏洞和解決辦法,需要的朋友可以參考下2014-03-03深入理解基于vue-cli的webpack打包優(yōu)化實踐及探索
這篇文章主要介紹了基于vue-cli的webpack打包優(yōu)化實踐及探索,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-10-10javascript 面向?qū)ο蠹夹g(shù)基礎(chǔ)教程
看了很多介紹javascript面向?qū)ο蠹夹g(shù)的文章,很暈.為什么?不是因為寫得不好,而是因為太深奧.2009-12-12