因為 DOM 性能瓶頸,大型列表存在難以克服的性能問題。 因此,就有了 “局部渲染” 的優化方案,這就是虛擬列表的核心思想。
成都創新互聯公司是一家專注于成都網站設計、做網站、成都外貿網站建設公司與策劃設計,建寧網站建設哪家好?成都創新互聯公司做網站,專注于網站建設10余年,網設計領域的專業建站公司;建站業務涵蓋:建寧等地區。建寧做網站價格咨詢:18980820575虛擬列表的實現,需要重點關注的問題一有以下幾點:
下面逐一分解說明。
可視區域計算
可視區域的計算,就是使用當前視口的高度、當前滾動條滾過的距離,得到一個可視區域的坐標區間。 算出可視區域的坐標區間之后,在去過濾出落在該區間內的列表項,這個過程,列表項的坐標也是必須能算出的。
思考以下情況,
根據這些條件,我們可以計算出,當前可視區域為第 11 項至第 20 項。
01 - 05,可視區域上方
+----+-----------+--------
| 06 | 100 ~ 120 |
+----+-----------+
| 07 | 120 ~ 140 |
+----+-----------+
| 08 | 140 ~ 160 | 可視區域
+----+-----------+
| 09 | 160 ~ 180 |
+----+-----------+
| 10 | 180 ~ 200 |
+----+-----------+--------
11 - N,可視區域下方
這是因為列表項高度是固定的,我們可以通過簡單的四則運算算出已經滾動過去的 100px 中,已經滾動走了 5 個列表項,因此可視區域是從第 6 項開始,而視口高度為 100px,能容納 100 / 20 即 5 個條目。
上面例子的情況非常簡單,也不存在性能問題,因此實際上并沒有展開討論的價值。 而還有另一種復雜很多的情況,那就是,列表項高度不固定,根據內容決定高度。
此時,我們就沒辦法直接使用四則運算一步到位算出可視區域對應的條目了。
而必須實現一種機制,記錄所有列表項的坐標,再通過檢查列表項是否落在視口內。
下面重點討論該問題。
列表項的坐標
列表項的坐標,可以通過以下公式定義:
<列表項 top 坐標值> = <上一項 top 坐標值> + <上一項的高度值>
本文題目:使用Vue實現一個虛擬列表的方法-創新互聯
分享地址:http://vcdvsql.cn/article46/jjeeg.html
成都網站建設公司_創新互聯,為您提供建站公司、網站設計公司、微信小程序、網頁設計公司、品牌網站制作、網站改版
聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯