偷偷摘套内射激情视频,久久精品99国产国产精,中文字幕无线乱码人妻,中文在线中文a,性爽19p

性能更優(yōu)越的小程序圖片懶加載方式

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

[[238685]]

意義

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

實現(xiàn)方式

傳統(tǒng)H5的懶加載方式都是通過監(jiān)聽頁面的scroll事件來實現(xiàn)的,結(jié)合viewport的高度來判斷。

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

這里說的是通過另外一種方式來實現(xiàn)

createIntersectionObserver

小程序基礎(chǔ)庫 1.9.3 開始支持,了解下

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

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

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

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

 

  1. //index.js  
  2. //獲取應(yīng)用實例  
  3. const app = getApp()  
  4. let lazyload;  
  5. Page({  
  6.     data: {  
  7.         classNote: 'item-',                    //循環(huán)節(jié)點前綴  
  8.         count: 0,                              //總共加載到多少張  
  9.         img: []                                //圖片列表  
  10.     },  
  11.     onReady: function () {  
  12.         //可以先初始化首屏需要展示的圖片  
  13.         that.setData({  
  14.             count: 5  
  15.         })  
  16.         //開始監(jiān)聽節(jié)點,注意需要在onReady才能監(jiān)聽,此時節(jié)點才渲染  
  17.         lazyload.observe();  
  18.     },  
  19.     viewPort: function () {  
  20.         const that = this;  
  21.         var intersectionObserver = wx.createIntersectionObserver();  
  22.         //這里bottom:100,是指顯示區(qū)域以下 100px 時,就會觸發(fā)回調(diào)函數(shù)。  
  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. 監(jiān)聽的節(jié)點需要先渲染,也就是說監(jiān)聽這個動作需要在onReady的時候
  2. 上述示例監(jiān)聽是依賴循環(huán)節(jié)點的class,最少需要先渲染一個節(jié)點才能監(jiān)聽
  3. 每次監(jiān)聽完一個循環(huán)節(jié)點后,結(jié)束監(jiān)聽,然后繼續(xù)監(jiān)聽下一個節(jié)點

結(jié)果

 

 

無論怎么快速滾動,F(xiàn)PS都能保持在60

總結(jié)

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

 

責(zé)任編輯:龐桂玉 來源: segmentfault
相關(guān)推薦

2020-11-18 09:30:29

圖片懶加載前端瀏覽器

2015-10-08 10:58:51

圖片懶加載

2022-06-07 08:18:49

懶加載Web前端

2024-04-29 08:16:18

2022-05-24 07:36:53

Java 8APIJava

2021-03-19 06:31:06

vue-lazyloa圖片懶加載項目

2009-11-11 16:13:19

路由器協(xié)議

2019-09-09 09:05:59

圖片框架懶加載

2022-04-28 08:52:40

懶加載Web

2010-07-28 09:35:23

Flex加載圖片

2011-09-07 09:33:57

tp link 802無線網(wǎng)絡(luò)

2012-03-28 10:05:19

PCCW mobile華為

2025-06-18 10:05:26

2014-04-01 11:06:46

VDI虛擬化

2017-03-28 10:11:12

Webpack 2React加載

2021-08-16 12:32:37

HashMap八股文面試

2023-08-24 16:42:29

Sample聊天實例應(yīng)用

2021-01-08 09:40:40

優(yōu)化VUE性能

2024-03-20 09:31:00

圖片懶加載性能優(yōu)化React

2011-07-18 15:01:55

WI-FI
點贊
收藏

51CTO技術(shù)棧公眾號