Javascript 加載和執(zhí)行-性能提高篇
更新時間:2012年12月28日 10:19:19 作者:
Javascript 在瀏覽器中的性能問題,可能是最重要的可用性問題;Js的阻塞性 瀏覽器用單一進程來處理UI進程和Js的執(zhí)行;不管是內(nèi)嵌的還是外鏈的,下載并立即執(zhí)行 因為它有可能會修改頁面
Js的阻塞性
Javascript 在瀏覽器中的性能問題,可能是最重要的可用性問題
Js的阻塞性 瀏覽器用單一進程來處理UI進程和Js的執(zhí)行
不管是內(nèi)嵌的還是外鏈的,下載并立即執(zhí)行 因為它有可能會修改頁面
頁面生存周期的概念
瀑布圖中看到了下載時間和executing time
在head中加入script 和link body加載到前不會輸出任何東西,因此會看到空白頁面
<script type="text/javascript">
document.write("The date is" + (new Date().toDateString()));
</script>
頁面在到script時,不知道script里會做什么,所以必然阻塞,等它執(zhí)行
Ie8 等瀏覽器能并行下載多個js等資源,但是還是對下載圖片有影響
結(jié)論, 將腳本放在底部加載
組織腳本
目標(biāo) 最小化遲延時間
問題
引用多個script文件 內(nèi)嵌多個script標(biāo)簽
每個http請求都會帶來性能上的開銷
緊跟在link 后的script 是個錯誤 它會等待css的加載,以求獲得最精準(zhǔn)的描繪
結(jié)論:減少script標(biāo)簽的數(shù)量
將多個js文件合并成一個,打包工具
yahoo的合并處理器
無阻塞的腳本
js傾向于阻止瀏覽器的某些處理過程,如http請求處理和界面更新.這是最重要的性能問題。于是要減少js文件大小和限制http請求數(shù)
但是功能豐富與代碼量之間的矛盾, 合并成單個文件卻體積大會鎖死瀏覽器一大段時間,于是我們需要逐步加載javascript文件
重點:在頁面加載完成后加載javascript文件
1、延遲加載腳本
defer 屬性
如果要下載的js文件不會進行dom操作,那么defer屬性有很大的用處,它能讓文件并行下載,并不會立即執(zhí)行,而會在onload事件后再執(zhí)行,適用于任何script標(biāo)簽
2、動態(tài)加載腳本
一個function
function loadScript(url,callback){
var script = document.createElement('script');
script.type = 'text/javascript';
if(script.readyState) { //IE
script.onreadyStatechange = function(){
if(script.readyState == 'loaded' || script.readyState == 'complete') {
script.onreadyStatechange = null;
callback();
}
} else {
script.onload = function(){
callback();
}
}
}
這里要注意瀏覽器的兼容性,刪除事件,
如果有多個文件需要這樣加載,那么可以
loadScript('file1.js', function(){
loadScript('file2.js',function(){
})
});
3、XHR腳本注入
var xhr = new XMLHttpRequest();
xhr.open('get','file1.js',true);
xhr.onreadystatechange= function(){
if(xhr.readyState == 4) {
if(xhr.status >= 200 && xhr.status <=300 || xhr.status==304) {
var oScript = document.createElement('script');
oScript.text = xhr.responseText;
document.body.appendChild(oScript);
}
}
}
304表示從緩存取 text將ajax的內(nèi)容放入text
它的優(yōu)點
兼容性好,異步, 缺點:不能擴域 不能從cdn取內(nèi)容
Javascript 在瀏覽器中的性能問題,可能是最重要的可用性問題
Js的阻塞性 瀏覽器用單一進程來處理UI進程和Js的執(zhí)行
不管是內(nèi)嵌的還是外鏈的,下載并立即執(zhí)行 因為它有可能會修改頁面
頁面生存周期的概念
瀑布圖中看到了下載時間和executing time
在head中加入script 和link body加載到前不會輸出任何東西,因此會看到空白頁面
復(fù)制代碼 代碼如下:
<script type="text/javascript">
document.write("The date is" + (new Date().toDateString()));
</script>
頁面在到script時,不知道script里會做什么,所以必然阻塞,等它執(zhí)行
Ie8 等瀏覽器能并行下載多個js等資源,但是還是對下載圖片有影響
結(jié)論, 將腳本放在底部加載
組織腳本
目標(biāo) 最小化遲延時間
問題
引用多個script文件 內(nèi)嵌多個script標(biāo)簽
每個http請求都會帶來性能上的開銷
緊跟在link 后的script 是個錯誤 它會等待css的加載,以求獲得最精準(zhǔn)的描繪
結(jié)論:減少script標(biāo)簽的數(shù)量
將多個js文件合并成一個,打包工具
yahoo的合并處理器
無阻塞的腳本
js傾向于阻止瀏覽器的某些處理過程,如http請求處理和界面更新.這是最重要的性能問題。于是要減少js文件大小和限制http請求數(shù)
但是功能豐富與代碼量之間的矛盾, 合并成單個文件卻體積大會鎖死瀏覽器一大段時間,于是我們需要逐步加載javascript文件
重點:在頁面加載完成后加載javascript文件
1、延遲加載腳本
defer 屬性
如果要下載的js文件不會進行dom操作,那么defer屬性有很大的用處,它能讓文件并行下載,并不會立即執(zhí)行,而會在onload事件后再執(zhí)行,適用于任何script標(biāo)簽
2、動態(tài)加載腳本
一個function
復(fù)制代碼 代碼如下:
function loadScript(url,callback){
var script = document.createElement('script');
script.type = 'text/javascript';
if(script.readyState) { //IE
script.onreadyStatechange = function(){
if(script.readyState == 'loaded' || script.readyState == 'complete') {
script.onreadyStatechange = null;
callback();
}
} else {
script.onload = function(){
callback();
}
}
}
這里要注意瀏覽器的兼容性,刪除事件,
如果有多個文件需要這樣加載,那么可以
復(fù)制代碼 代碼如下:
loadScript('file1.js', function(){
loadScript('file2.js',function(){
})
});
3、XHR腳本注入
復(fù)制代碼 代碼如下:
var xhr = new XMLHttpRequest();
xhr.open('get','file1.js',true);
xhr.onreadystatechange= function(){
if(xhr.readyState == 4) {
if(xhr.status >= 200 && xhr.status <=300 || xhr.status==304) {
var oScript = document.createElement('script');
oScript.text = xhr.responseText;
document.body.appendChild(oScript);
}
}
}
304表示從緩存取 text將ajax的內(nèi)容放入text
它的優(yōu)點
兼容性好,異步, 缺點:不能擴域 不能從cdn取內(nèi)容
相關(guān)文章
JS判斷輸入的字符串是否是數(shù)字的方法(正則表達式)
下面小編就為大家?guī)硪黄狫S判斷輸入的字符串是否是數(shù)字的方法(正則表達式)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2016-11-11JavaScript中數(shù)據(jù)結(jié)構(gòu)與算法(五):經(jīng)典KMP算法
這篇文章主要介紹了JavaScript中數(shù)據(jù)結(jié)構(gòu)與算法(五):經(jīng)典KMP算法,本文詳解了KMP算法的方方面在,需要的朋友可以參考下2015-06-06javascript設(shè)計模式 – 享元模式原理與用法實例分析
這篇文章主要介紹了javascript設(shè)計模式 – 享元模式,結(jié)合實例形式分析了javascript享元模式相關(guān)概念、原理、用法及操作注意事項,需要的朋友可以參考下2020-04-04用JS實現(xiàn)一個頁面多個css樣式實現(xiàn)
在Hello,Yang中看見的一篇文章,感覺很有用,轉(zhuǎn)來這里……2008-05-05js實現(xiàn)獲取當(dāng)前時間是本月第幾周的方法
這篇文章主要介紹了js實現(xiàn)獲取當(dāng)前時間是本月第幾周的方法,涉及javascript針對日期及時間的相關(guān)操作技巧,非常簡單實用,需要的朋友可以參考下2015-08-08