国产99久久精品_欧美日本韩国一区二区_激情小说综合网_欧美一级二级视频_午夜av电影_日本久久精品视频

最新文章專題視頻專題問答1問答10問答100問答1000問答2000關(guān)鍵字專題1關(guān)鍵字專題50關(guān)鍵字專題500關(guān)鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關(guān)鍵字專題關(guān)鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
問答文章1 問答文章501 問答文章1001 問答文章1501 問答文章2001 問答文章2501 問答文章3001 問答文章3501 問答文章4001 問答文章4501 問答文章5001 問答文章5501 問答文章6001 問答文章6501 問答文章7001 問答文章7501 問答文章8001 問答文章8501 問答文章9001 問答文章9501
當(dāng)前位置: 首頁 - 科技 - 知識百科 - 正文

JavaScript一次性展示幾萬條數(shù)據(jù)實例代碼

來源:懂視網(wǎng) 責(zé)編:小OO 時間:2020-11-27 20:22:59
文檔

JavaScript一次性展示幾萬條數(shù)據(jù)實例代碼

有一位同事跟大家說他在網(wǎng)上看到一道面試題:“如果后臺傳給前端幾萬條數(shù)據(jù),前端怎么渲染到頁面上?”,如何回答? 于是辦公室沸騰了,同事們討論開了,你一言我一語說出自己的方案。有的說直接循環(huán)遍歷生成html插到頁面上;有的說應(yīng)該用分頁來處理;還有的說這個面試官是個白癡,哪有后臺傳幾萬條數(shù)據(jù)給前端這種情況的;我仔細(xì)思考了一下,先不論后端到底會不會白癡到傳幾萬條數(shù)據(jù)給前端,假如真碰到這種情況,那么如果前端獲取到數(shù)據(jù)以后,直接將數(shù)據(jù)轉(zhuǎn)換成html字符串,通過DOM操作插入到頁面,勢必導(dǎo)致頁面運行出現(xiàn)卡頓,為此我還特意寫了一個 demo測試了一下,代碼如下:
推薦度:
導(dǎo)讀有一位同事跟大家說他在網(wǎng)上看到一道面試題:“如果后臺傳給前端幾萬條數(shù)據(jù),前端怎么渲染到頁面上?”,如何回答? 于是辦公室沸騰了,同事們討論開了,你一言我一語說出自己的方案。有的說直接循環(huán)遍歷生成html插到頁面上;有的說應(yīng)該用分頁來處理;還有的說這個面試官是個白癡,哪有后臺傳幾萬條數(shù)據(jù)給前端這種情況的;我仔細(xì)思考了一下,先不論后端到底會不會白癡到傳幾萬條數(shù)據(jù)給前端,假如真碰到這種情況,那么如果前端獲取到數(shù)據(jù)以后,直接將數(shù)據(jù)轉(zhuǎn)換成html字符串,通過DOM操作插入到頁面,勢必導(dǎo)致頁面運行出現(xiàn)卡頓,為此我還特意寫了一個 demo測試了一下,代碼如下:

本文主要介紹了JavaScript一次性展示幾萬條數(shù)據(jù)的實現(xiàn)方法。具有很好的參考價值,下面跟著小編一起來看下吧

有一位同事跟大家說他在網(wǎng)上看到一道面試題:“如果后臺傳給前端幾萬條數(shù)據(jù),前端怎么渲染到頁面上?”,如何回答? 于是辦公室沸騰了, 同事們討論開了, 你一言我一語說出自己的方案。 有的說直接循環(huán)遍歷生成html插到頁面上;有的說應(yīng)該用分頁來處理;還有的說這個面試官是個白癡, 哪有后臺傳幾萬條數(shù)據(jù)給前端這種情況的;我仔細(xì)思考了一下,先不論后端到底會不會白癡到傳幾萬條數(shù)據(jù)給前端,假如真碰到這種情況,那么如果前端獲取到數(shù)據(jù)以后, 直接將數(shù)據(jù)轉(zhuǎn)換成html字符串,通過DOM操作插入到頁面,勢必導(dǎo)致頁面運行出現(xiàn)卡頓, 為此我還特意寫了一個 demo測試了一下, 代碼如下

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í)行流程中運行,那似乎不但無法解決糟糕的頁面卡頓問題,反而會將代碼復(fù)雜化。 類似的問題在其它語言最佳的解決方案是使用多線程,Javascript雖然沒有多線程,但是setTimeout和setInterval兩個函數(shù)卻能起到和多線程差不多的效果。 因此,要解決這個問題, 其中的setTimeout便可以大顯身手。 setTimeout函數(shù)的功能可以看作是在指定時間之后啟動一個新的線程來完成任務(wù)。

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

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

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

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

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

是為了保證不同的線程中最終插入html到文檔中時順序的一致性, 不至于同時執(zhí)行的代碼在插入html時互相篡位。

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

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

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

聲明:本網(wǎng)頁內(nèi)容旨在傳播知識,若有侵權(quán)等問題請及時與本網(wǎng)聯(lián)系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

文檔

JavaScript一次性展示幾萬條數(shù)據(jù)實例代碼

有一位同事跟大家說他在網(wǎng)上看到一道面試題:“如果后臺傳給前端幾萬條數(shù)據(jù),前端怎么渲染到頁面上?”,如何回答? 于是辦公室沸騰了,同事們討論開了,你一言我一語說出自己的方案。有的說直接循環(huán)遍歷生成html插到頁面上;有的說應(yīng)該用分頁來處理;還有的說這個面試官是個白癡,哪有后臺傳幾萬條數(shù)據(jù)給前端這種情況的;我仔細(xì)思考了一下,先不論后端到底會不會白癡到傳幾萬條數(shù)據(jù)給前端,假如真碰到這種情況,那么如果前端獲取到數(shù)據(jù)以后,直接將數(shù)據(jù)轉(zhuǎn)換成html字符串,通過DOM操作插入到頁面,勢必導(dǎo)致頁面運行出現(xiàn)卡頓,為此我還特意寫了一個 demo測試了一下,代碼如下:
推薦度:
標(biāo)簽: 數(shù)據(jù) js 代碼
  • 熱門焦點

最新推薦

猜你喜歡

熱門推薦

專題
Top
主站蜘蛛池模板: 国产一区二区在线视频 | 亚洲最新在线 | 久久精品国产亚洲精品2020 | 亚洲国产成人久久综合碰碰动漫3d | 日韩大片免费观看视频播放 | 一区二区三区四区电影 | 亚洲欧美视频在线观看 | 午夜视频免费观看 | 最近免费中文字幕大全免费版视频 | 欧美在线国产 | 国产精品久久久久久久久99热 | 久久久精品一区二区三区 | 亚洲精品99久久久久中文字幕 | 国产精品成人一区二区 | 欧美精品第1页在线播放 | 全免费a级毛片免费看不卡 青青色在线视频 | 久久婷婷久久一区二区三区 | 欧美 亚洲 一区 | 国产亚洲一区二区三区不卡 | 欧美黄色第一页 | 在线视频亚洲 | 一级毛片一级毛片一级毛片 | 国产成人精品一区二区免费 | 97国产精品欧美一区二区三区 | 在线国产观看 | 国语对白91| 真人一级一级毛片免费观看 | 久久亚洲一级α片 | 日韩一区二区久久久久久 | 自拍 欧美 日韩 | 免费观看欧美一区二区三区 | 91精品国产品国语在线不卡 | 高清国产精品久久 | 中文国产成人精品少久久 | 亚洲女同一区二区 | 五十路息子 | 欧美va免费精品高清在线 | 国产成人综合久久精品亚洲 | 四虎影视永久在线 | 欧美日韩国产一区二区三区 | 欧美网址在线观看 |