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

JavaScript如何一次性展示幾萬條數(shù)據(jù)

 更新時間:2017年03月30日 09:08:04   作者:陳宏鴻  
本文主要介紹了JavaScript一次性展示幾萬條數(shù)據(jù)的實現(xiàn)方法。具有很好的參考價值,下面跟著小編一起來看下吧

有一位同事跟大家說他在網(wǎng)上看到一道面試題:“如果后臺傳給前端幾萬條數(shù)據(jù),前端怎么渲染到頁面上?”,如何回答? 于是辦公室沸騰了, 同事們討論開了, 你一言我一語說出自己的方案。 有的說直接循環(huán)遍歷生成html頁面上;有的說應該用分頁來處理;通過DOM操作到頁面,勢必導致頁面運行出現(xiàn)卡頓, 為此我還特意寫了一個 demo測試了一下, 代碼如下

$.get("data.json", function (response) {
 //response里大概有13萬條數(shù)據(jù)
 loadAll( response );
});
function loadAll(response) {
 var html = "";
 for (var i = 0; i < response.length; i++) {
  var item = response[i];
  html += "<li>title:" + item.title + " content:" + item.content + "</li>";
 }
 $("#content").html(html);
}

data.json中大概有13萬條數(shù)據(jù)左右, 通過ajax獲取數(shù)據(jù)后以最簡單粗暴的方法展示數(shù)據(jù),在chrome瀏覽器下, 刷新頁面到數(shù)據(jù)顯示,我心中默數(shù), 整個過程大概花掉5秒鐘左右的時間, 卡頓非常明顯。 我大致觀察了一下代碼的運行時間,發(fā)現(xiàn)循環(huán)生成字符串這過程其實并不算太耗時, 性能瓶頸是在將html字符串到文檔中這個過程上, 也就是 $("#content").html(html); 這句代碼的執(zhí)行, 畢竟有13萬個li元素要被挺入到文檔里面, 頁面渲染速度緩慢也在情理之中。

既然一次渲染13萬條數(shù)據(jù)會造成頁面加載速度緩慢,那么我們可以不要一次性渲染這么多數(shù)據(jù),而是分批次渲染, 比如一次10000條,分13次來完成, 這樣或許會對頁面的渲染速度有提升。 然而,如果這13次操作在同一個代碼執(zhí)行流程中運行,那似乎不但無法解決糟糕的頁面卡頓問題,反而會將代碼復雜化。 類似的問題在其它語言最佳的解決方案是使用多線程,JavaScript雖然沒有多線程,但是setTimeout和setInterval兩個函數(shù)卻能起到和多線程差不多的效果。 因此,要解決這個問題, 其中的setTimeout便可以大顯身手。 setTimeout函數(shù)的功能可以看作是在指定時間之后啟動一個新的線程來完成任務。

$.get("data.json", function (response) {
  //response里大概有13萬條數(shù)據(jù)
  loadAll( response );
});

function loadAll(response) {
  //將13萬條數(shù)據(jù)分組, 每組500條,一共260組
  var groups = group(response);
  for (var i = 0; i < groups.length; i++) {
    //閉包, 保持i值的正確性
    window.setTimeout(function () {
      var group = groups[i];
      var index = i + 1;
      return function () {
        //分批渲染
        loadPart( group, index );
      }
    }(), 1);
  }
}

//數(shù)據(jù)分組函數(shù)(每組500條)
function group(data) {
  var result = [];
  var groupItem;
  for (var i = 0; i < data.length; i++) {
    if (i % 500 == 0) {
      groupItem != null && result.push(groupItem);
      groupItem = [];
    }
    groupItem.push(data[i]);
  }
  result.push(groupItem);
  return result;
}

var currIndex = 0;

//加載某一批數(shù)據(jù)的函數(shù)
function loadPart( group, index ) {
  var html = "";
  for (var i = 0; i < group.length; i++) {
    var item = group[i];
    html += "<li>title:" + item.title + index + " content:" + item.content + index + "</li>";
  }
  //保證順序不錯亂
  while (index - currIndex == 1) {
    $("#content").append(html);
    currIndex = index;
  }
}

以上代碼大致的執(zhí)行流程是

1. 用ajax獲取到需要處理的數(shù)據(jù), 共13萬條

2. 將數(shù)組分組,每組500條,一共260組

3. 循環(huán)這260組數(shù)據(jù),分別處理每一組數(shù)據(jù), 利用setTimeout函數(shù)開啟一個新的執(zhí)行線程(異步),防止主線程因渲染大量數(shù)據(jù)導致阻塞。

loadPart函數(shù)中有這段代碼

while (index - currIndex == 1) {
 $("#content").append(html);
 currIndex = index;
}

通過這種方式執(zhí)行, 頁面瞬間就刷出來了,不用絲毫等待時間。 從同步改為異步,雖然代碼的整體資源消耗增加了, 但是頁面卻能瞬間響應, 而且, 前端的運行環(huán)境是用戶的電腦,因此些許的性能損失帶來的用戶體驗提升相對來說還是值得的。

雖然示例中提到的情況在現(xiàn)實環(huán)境中幾乎不可能出現(xiàn), 但是在我們平時的工作中總會有一些似是而非的場景出現(xiàn), 利用里面的處理思路, 或許對我們解決問題會有一定的幫助。

ps:setTimeout并不算真正的多線程, 但是為了方便表達,便借用了線程一詞

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

相關文章

  • javascript中的糖衣語法Promise對象詳解

    javascript中的糖衣語法Promise對象詳解

    這篇文章主要介紹了javascript中的糖衣語法Promise對象詳解,Promise 對象代表了未來將要發(fā)生的事件,用來傳遞異步操作的消息,本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-07-07
  • js實例入門(簡單展開或關閉)

    js實例入門(簡單展開或關閉)

    簡直的展開或關閉
    2008-11-11
  • js提交form表單,并傳遞參數(shù)的實現(xiàn)方法

    js提交form表單,并傳遞參數(shù)的實現(xiàn)方法

    下面小編就為大家?guī)硪黄猨s提交form表單,并傳遞參數(shù)的實現(xiàn)方法。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2016-05-05
  • 微信小程序登錄方法之授權登陸及獲取微信用戶手機號

    微信小程序登錄方法之授權登陸及獲取微信用戶手機號

    最近改了一個公司項目,新增加了一個獲取用戶手機號功能,里面用到了關于獲取用戶信息和用戶手機號的功能,下面這篇文章主要給大家介紹了關于微信小程序登錄方法之授權登陸及獲取微信用戶手機號的相關資料,需要的朋友可以參考下
    2022-07-07
  • 仿新浪微博登陸郵箱提示效果的js代碼

    仿新浪微博登陸郵箱提示效果的js代碼

    本文為大家介紹下使用js仿新浪微博登陸郵箱提示效果,具體實現(xiàn)代碼如下,感興趣的朋友可以參考下,希望對大家有所幫組
    2013-08-08
  • 詳解JavaScript 事件流

    詳解JavaScript 事件流

    這篇文章主要介紹了JavaScript 事件流的相關資料,幫助大家更好的理解和學習JavaScript,感興趣的朋友可以了解下
    2020-09-09
  • JS實現(xiàn)從連接中獲取youtube的key實例

    JS實現(xiàn)從連接中獲取youtube的key實例

    這篇文章主要介紹了JS實現(xiàn)從連接中獲取youtube的key的方法,涉及javascript字符串操作的相關技巧,需要的朋友可以參考下
    2015-07-07
  • 微信小程序獲取手機網(wǎng)絡狀態(tài)的方法【附源碼下載】

    微信小程序獲取手機網(wǎng)絡狀態(tài)的方法【附源碼下載】

    這篇文章主要介紹了微信小程序獲取手機網(wǎng)絡狀態(tài)的方法,涉及微信小程序wx.getNetworkType函數(shù)檢查網(wǎng)絡連接狀態(tài)的相關使用技巧,并附帶源碼供讀者下載參考,需要的朋友可以參考下
    2017-12-12
  • easyui關于validatebox實現(xiàn)多重規(guī)則驗證的方法(必看)

    easyui關于validatebox實現(xiàn)多重規(guī)則驗證的方法(必看)

    下面小編就為大家?guī)硪黄猠asyui關于validatebox實現(xiàn)多重規(guī)則驗證的方法(必看)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-04-04
  • Webpack中使用環(huán)境變量的各種正確姿勢

    Webpack中使用環(huán)境變量的各種正確姿勢

    我們在開發(fā)項目中都會遇到這種場景,區(qū)分開發(fā)環(huán)境、生產(chǎn)環(huán)境、測試環(huán)境,不同場景請求不同的接口Api,這時候項目中配置的「環(huán)境變量」就登場啦,這篇文章主要給大家介紹了關于Webpack中使用環(huán)境變量的各種正確姿勢,需要的朋友可以參考下
    2021-09-09

最新評論