成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

性能更優越的小程序圖片懶加載方式

開發 前端
懶加載或者可以說是延遲加載,針對非首屏或者用戶"看不到"的地方延遲加載,有利于頁面首屏加載速度快、節約了流量,用戶體驗好。

[[238685]]

意義

懶加載或者可以說是延遲加載,針對非首屏或者用戶"看不到"的地方延遲加載,有利于頁面首屏加載速度快、節約了流量,用戶體驗好。

實現方式

傳統H5的懶加載方式都是通過監聽頁面的scroll事件來實現的,結合viewport的高度來判斷。

小程序也類似,通過監聽頁面onPageScroll事件獲取當前滾動的數據,結合getSystemInfo獲取設備信息來判斷。由于scroll事件密集發生,計算量很大,經常會造成FPS降低、頁面卡頓等問題。

這里說的是通過另外一種方式來實現

createIntersectionObserver

小程序基礎庫 1.9.3 開始支持,了解下

    節點布局交叉狀態API可用于監聽兩個或多個組件節點在布局位置上的相交狀態。這一組API常??梢杂糜谕茢嗄承┕濣c是否可以被用戶看見、有多大比例可以被用戶看見。

API涉及到的概念總共有5個

  • 參照節點:監聽的參照節點,取它的布局區域作為參照區域。如果有多個參照節點,則會取它們布局區域的 交集 作為參照區域。頁面顯示區域也可作為參照區域之一。
  • 目標節點:監聽的目標,默認只能是一個節點(使用 selectAll 選項時,可以同時監聽多個節點)。
  • 相交區域:目標節點的布局區域與參照區域的相交區域。
  • 相交比例:相交區域占參照區域的比例。
  • 閾值:相交比例如果達到閾值,則會觸發監聽器的回調函數。閾值可以有多個。

通過以上API和概念的了解,可以獲取到圖片是否可以被用戶看見或者即將被看見,通過回調將圖片加載顯示出來,然后監聽下一組即將被顯示的圖片,這樣就可以達到懶加載圖片的方式,以下是代碼展示

 

  1. //index.js  
  2. //獲取應用實例  
  3. const app = getApp()  
  4. let lazyload;  
  5. Page({  
  6.     data: {  
  7.         classNote: 'item-',                    //循環節點前綴  
  8.         count: 0,                              //總共加載到多少張  
  9.         img: []                                //圖片列表  
  10.     },  
  11.     onReady: function () {  
  12.         //可以先初始化首屏需要展示的圖片  
  13.         that.setData({  
  14.             count: 5  
  15.         })  
  16.         //開始監聽節點,注意需要在onReady才能監聽,此時節點才渲染  
  17.         lazyload.observe();  
  18.     },  
  19.     viewPort: function () {  
  20.         const that = this;  
  21.         var intersectionObserver = wx.createIntersectionObserver();  
  22.         //這里bottom:100,是指顯示區域以下 100px 時,就會觸發回調函數。  
  23.         intersectionObserver.relativeToViewport({bottom: 100}).observe(this.data.classNote + this.data.count, (res) => {  
  24.             if(res.boundingClientRect.top > 0){  
  25.                 intersectionObserver.disconnect()  
  26.                 that.setData({  
  27.                     count: that.data.count + 5  
  28.                 })  
  29.                 that.viewPort();  
  30.             }  
  31.         })  
  32.     }  
  33. })  
  34.  
  35. //page.wxml  
  36. <view 
  37.     <view wx:for="{{img}}" class="item-{{index}}" 
  38.         <image style="display: {{index < count ? 'block' : 'none'}}" src="{{item}}"></image>  
  39.     </view 
  40. </view

這里有3點需要注意的

  1. 監聽的節點需要先渲染,也就是說監聽這個動作需要在onReady的時候
  2. 上述示例監聽是依賴循環節點的class,最少需要先渲染一個節點才能監聽
  3. 每次監聽完一個循環節點后,結束監聽,然后繼續監聽下一個節點

結果

 

 

無論怎么快速滾動,FPS都能保持在60

總結

H5其實也有一個類似的API,小程序的使用方式跟H5也是很類似,有很多東西都可以參考。針對上述監聽的方式,我這邊簡單封裝了一個庫來調用,歡迎star。 

 

責任編輯:龐桂玉 來源: segmentfault
相關推薦

2015-10-08 10:58:51

圖片懶加載

2022-06-07 08:18:49

懶加載Web前端

2024-04-29 08:16:18

2020-11-18 09:30:29

圖片懶加載前端瀏覽器

2022-05-24 07:36:53

Java 8APIJava

2009-11-11 16:13:19

路由器協議

2019-09-09 09:05:59

圖片框架懶加載

2021-03-19 06:31:06

vue-lazyloa圖片懶加載項目

2022-04-28 08:52:40

懶加載Web

2010-07-28 09:35:23

Flex加載圖片

2011-09-07 09:33:57

tp link 802無線網絡

2012-03-28 10:05:19

PCCW mobile華為

2025-06-18 10:05:26

2023-08-24 16:42:29

Sample聊天實例應用

2014-04-01 11:06:46

VDI虛擬化

2024-03-20 09:31:00

圖片懶加載性能優化React

2011-07-18 15:01:55

WI-FI

2024-01-11 08:36:47

懶加載零拷貝前端

2024-10-16 10:20:00

2017-03-28 10:11:12

Webpack 2React加載
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 天天爱天天操 | 亚洲精品一区二区在线观看 | 黄色av一区 | 99在线免费视频 | 国产在线一区二 | 久热精品在线播放 | 黄色免费三级 | 亚洲国产伊人 | 精品日韩一区 | av二区三区 | 日韩精品在线一区 | 亚洲一区二区在线播放 | 中文字幕乱码一区二区三区 | 免费在线观看av网站 | 香蕉国产在线视频 | 久久日韩精品一区二区三区 | 久久精品欧美一区二区三区不卡 | 欧美国产日韩一区二区三区 | 99热在线观看精品 | 久久999 | 午夜精品影院 | 亚洲国产在 | 成人欧美一区二区三区黑人孕妇 | 91精品国产99久久 | 久久av一区二区三区 | 精品视频免费 | 九色国产 | 东京久久| 在线第一页 | 国产亚洲精品久久情网 | 成人在线播放网站 | 人人干在线视频 | 日韩精品一二三 | 欧美亚洲国产精品 | 中文字幕亚洲视频 | 日韩欧美在线播放 | 中文字幕在线观看 | 日本国产精品视频 | 成人h免费观看视频 | chinese中国真实乱对白 | 久久日韩粉嫩一区二区三区 |