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

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

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

[[238685]]

意義

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

實現方式

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

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

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

createIntersectionObserver

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

    節點布局交叉狀態API可用于監聽兩個或多個組件節點在布局位置上的相交狀態。這一組API常常可以用于推斷某些節點是否可以被用戶看見、有多大比例可以被用戶看見。

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
相關推薦

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

路由器協議

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無線網絡

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聊天實例應用

2021-01-08 09:40:40

優化VUE性能

2024-03-20 09:31:00

圖片懶加載性能優化React

2011-07-18 15:01:55

WI-FI
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 操人视频在线观看 | 精品久久国产视频 | 成人高清视频在线观看 | 黄色永久免费 | 久久久久久国产 | 99国产精品99久久久久久粉嫩 | 久热免费在线 | 久久久这里只有17精品 | 亚洲一区 中文字幕 | 亚洲国产成人精品久久 | 成人小视频在线观看 | 日韩精品| 久久久精品日本 | 亚洲精选久久 | 日本h片在线观看 | 国产最新网址 | 黄色一级特级片 | 欧美久操网 | 亚洲精品久久久一区二区三区 | 日韩精品一区二区三区在线 | 在线一级片 | 日本电影免费完整观看 | 国产美女特级嫩嫩嫩bbb片 | 无码日韩精品一区二区免费 | 国产欧美精品一区二区色综合 | 欧美一区两区 | 粉嫩一区二区三区国产精品 | 日韩一区二区在线视频 | 成人免费一区二区三区视频网站 | 最新日韩av | 国产一区二区精品在线 | 欧美在线综合 | 免费国产视频在线观看 | 韩国欧洲一级毛片 | 日韩精品极品视频在线观看免费 | 婷婷久久精品一区二区 | 男女羞羞的网站 | 性欧美精品一区二区三区在线播放 | 看片国产 | 欧美一区二区在线观看视频 | 欧美男人天堂 |