欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

js 性能優(yōu)化之快速響應(yīng)的用戶界面

 更新時間:2017年02月15日 16:24:17   作者:小蚊  
本文主要介紹了js性能優(yōu)化的快速響應(yīng)的用戶界面。具有很好的參考價值,下面跟著小編一起來看下吧

用于執(zhí)行JavaScript和更新用戶界面的進程通常被稱為“瀏覽器UI線程”。JavaScript和用戶界面更新在同一個進程中運行,因此一次只能處理一件事情。 

·任何JavaScript任務(wù)都不應(yīng)當執(zhí)行超過100毫秒,過長的運行時間導(dǎo)致UI更新出現(xiàn)明顯延遲,從而會影響用戶體驗。 

·瀏覽器有兩類限制JavaScript任務(wù)的運行時間的機制,調(diào)用棧大小限制(即記錄自腳本開始以來執(zhí)行的語句的數(shù)量)和長時間運行腳本限制(記錄腳本執(zhí)行的總時長,超時的時候會有彈框提示用戶[chrome沒有單獨的程云霞腳本限制,替代做法是依賴其通用奔潰檢測系統(tǒng)來處理此類問題])。

一些優(yōu)化JavaScript任務(wù)時間的常見做法:

①使定時器讓出時間片段

1.使用定時器處理數(shù)組。當處理過程不須同步,數(shù)據(jù)不須按順序處理時。即可考慮用定時器分解任務(wù)。

如:

function processArray(items,process,callback){
 var todo = items.concat();
 setTimeout(function(){
 process(todo.shift());
 
 if(todo.length > 0){
 setTimeout(arguments.callee,25);
 } else {
 callback(items);
 }
 },25);
}
var items = [1,2,3];
function output(value){
 console.log(value);
} 
processArray(items,outputValue,function(){
 console.log('finished output!')
});

②分割任務(wù)

如果一個函數(shù)的運行時間過長,那么可以把它拆分為一系列能在較短時間內(nèi)完成的子函數(shù)。

如:

function multistep(steps,args,callback){
 var tasks = steps.concat();
 setTimeout(function(){
 var task = tasks.shift();
 task.apply(null,args||[]);
 
 if(tasks.length > 0){
 setTimeout(arguments.callee,25);
 } else {
 callback();
 }
 },25);
}
function saveDocument(id){
 var tasks = [open,write,close];
 multistep(tasks,[id],function(){
 console.log('finished!');
 })
} 

③記錄代碼的運行時間

有時每次只執(zhí)行一個任務(wù)的效率不高,且在兩次之間產(chǎn)生25ms的延遲就更不好了。所以可以添加時間檢測機制來改進processArray()方法。

如:

function timeProcessArray(items,process,callback){
 var todo = items.concat();
 setTimeout(function(){
 var start = +new Date();
 do{
 process(todo.shift());
 }while(todo.length > 0 &&(+new Date() - start < 50)) ;
 if(todo.length > 0){
 setTimeout(arguments.callee,25);
 } else {
 callback(items);
 }
 },25);
}

注意,定時器雖然可以提高性能,但是過度使用會適得其反。需要控制web應(yīng)用中的使用數(shù)量。

④使用Worker

Web Worker是新版瀏覽器支持的特性,它允許在UI線程外部執(zhí)行JavaScript代碼,從而避免鎖定UI。

參考資料:http://www.alloyteam.com/2015/11/deep-in-web-worker/

備注:

個人覺得,Worker的缺陷還是太多了。用不起來,而且要慎用。

以上就是本文的全部內(nèi)容,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作能帶來一定的幫助,同時也希望多多支持腳本之家!

相關(guān)文章

  • JavaScript閉包原理與使用介紹

    JavaScript閉包原理與使用介紹

    閉包是js的一個難點也是它的一個特色,是我們必須掌握的js高級特性,下面這篇文章主要給大家介紹了關(guān)于JavaScript閉包函數(shù)的相關(guān)資料,需要的朋友可以參考下
    2022-10-10
  • js獲取指定字符前/后的字符串簡單實例

    js獲取指定字符前/后的字符串簡單實例

    下面小編就為大家?guī)硪黄猨s獲取指定字符前/后的字符串簡單實例。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2016-10-10
  • es6中Promise 對象基本功能與用法實例分析

    es6中Promise 對象基本功能與用法實例分析

    這篇文章主要介紹了es6中Promise 對象基本功能與用法,結(jié)合實例形式分析了es6中Promise對象的基本功能、用法及操作注意事項,需要的朋友可以參考下
    2020-02-02
  • BootStrap Table前臺和后臺分頁對JSON格式的要求

    BootStrap Table前臺和后臺分頁對JSON格式的要求

    Bootstrap是一款前端非常流行的框架,其中的表格更為大家經(jīng)常使用。下面通過本文給大家介紹BootStrap Table前臺和后臺分頁對JSON格式的要求,一起看看吧
    2017-06-06
  • 無縫滾動改進版支持上下左右滾動(封裝成函數(shù))

    無縫滾動改進版支持上下左右滾動(封裝成函數(shù))

    無縫滾動改進版,封裝成函數(shù),同時支持上下左右無縫滾動。
    2012-12-12
  • JavaScript如何刪除字符串中子字符串

    JavaScript如何刪除字符串中子字符串

    本文介紹了如何從?JavaScript?中的字符串中刪除子字符串,并提供了兩種常用的方法:replace()?方法和?split()?方法,結(jié)合示例代碼給大家介紹的非常詳細,需要的朋友參考下吧
    2023-05-05
  • 微信小程序四種彈窗方式實例

    微信小程序四種彈窗方式實例

    微信小程序彈窗是小程序在需要提示用戶的時候,顯示的一種交互形式,下面這篇文章主要給大家介紹了關(guān)于微信小程序四種彈窗方式的相關(guān)資料,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下
    2023-06-06
  • webpack 模塊熱替換原理

    webpack 模塊熱替換原理

    這篇文章主要介紹了webpack 模塊熱替換原理,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-04-04
  • JS取數(shù)字小數(shù)點后兩位或n位的簡單方法

    JS取數(shù)字小數(shù)點后兩位或n位的簡單方法

    下面小編就為大家?guī)硪黄狫S取數(shù)字小數(shù)點后兩位或n位的簡單方法。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2016-10-10
  • 微信小程序?qū)崿F(xiàn)寫入讀取緩存詳解

    微信小程序?qū)崿F(xiàn)寫入讀取緩存詳解

    這篇文章主要介紹了微信小程序?qū)崿F(xiàn)寫入緩存與讀取緩存詳解,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2019-08-08

最新評論