在线看毛片视频-国产免费av在线-欧美日韩一区二区三区-国产成人无码av在线播放无广告-亚洲人va欧美va人人爽-国产第一草草-西班牙黄色片-四虎在线网站8848-最新av片免费网站入口-东京热无码中文字幕av专区-日本大人吃奶视频xxxx-欧美精品一区二区三区四区五区-国产片天天弄-国产免费内射又粗又爽密桃视频-欧美爱爱网站-日韩v欧美

當前位置:雨林木風下載站 > 應用軟件教程 > 詳細頁面

什么是懶加載?小程序中圖片懶加載的2種完成方法

什么是懶加載?小程序中圖片懶加載的2種完成方法

更新時間:2025-09-20 文章作者:未知 信息來源:網絡 閱讀次數:

微信小程序,簡稱小程序,英文名Mini Program,是一種不需要下載安裝即可使用的應用,它實現了應用“觸手可及”的夢想,用戶掃一掃或搜一下即可打開應用。小程序是一種不用下載就能使用的應用,也是一...
微信小程序,簡稱小程序,英文名Mini Program,是一種不需要下載安裝即可使用的應用,它實現了應用“觸手可及”的夢想,用戶掃一掃或搜一下即可打開應用。小程序是一種不用下載就能使用的應用,也是一項門檻非常高的創新,經過將近兩年的發展,已經構造了新的小程序開發環境和開發者生態。
本篇文章給大家帶來的內容是關于什么是懶加載?小程序中圖片懶加載的兩種實現方法 ,有一定的參考價值,有需要的朋友可以參考一下,希望對你有所幫助。

定義

懶加載,前端人都知道的一種性能優化方式,簡單的來說,只有當圖片出現在瀏覽器的可視區域內時,才設置圖片正真的路徑,讓圖片顯示出來。這就是圖片懶加載。

實現原理

監聽頁面的scroll事件,判讀元素距離頁面的top值是否是小于等于頁面的可視高度

判斷邏輯代碼如下

element.getBoundingClientRect().top <= document.documentElement.clientHeight ? 顯示 : 默認

我們知道小程序頁面的腳本邏輯是在JsCore中運行,JsCore是一個沒有窗口對象的環境,所以不能在腳本中使用window,也無法在腳本中操作組件。

所以關于圖片懶加載就需要在數據上面做文章了。

頁面

頁面上面只需要根據數據的某一個字段來判斷是否顯示圖片就可以了,字段為Boolean類型,當為false的時候顯示默認圖片就行了。

代碼大概長成這樣

<view wx:for="{{list}}" class='item item-{{index}}'
 wx:key="{{index}}">
    <image class="{{item.show ? 'active': ''}}" src="{{item.show ? item.src : item.def}}"></image>
</view>

布局跟簡單,view組件里面有個圖片,并循環list,有多少就展示多少

image組件的src字段通過每一項的show來進行綁定,active是加了個透明的過渡

樣式

image{
    transition: all .3s ease;
    opacity: 0;
}
.active{
    opacity: 1;
}

邏輯

本位主要講解懶加載,所以把數據寫死在頁面上了

數據結構如下:

428961300-5b94c62aa3c9e_articlex.jpg

我們使用兩種方式來實現懶加載,準備好沒有,一起來快樂的擼碼吧。

WXML節點信息

小程序支持調用createSelectQuery創建一個SelectorQuery實例,并使用select方法來選擇節點,并通過boundingClientRect來獲取節點信息。

wx.createSelectorQuery().select('.item').boundingClientRect((ret)=>{
    console.log(ret)
}).exec()

顯示結果如下

2959195174-5b94c62a9e79c_articlex.jpg悄悄告訴你,小程序里面有個onPageScroll函數,是用來監聽頁面的滾動的。
還有個getSystemInfo函數,可以獲取獲取系統信息,里面包含屏幕的高度。

接下來,思路就透徹了吧。還是上面的邏輯, 扒拉扒拉直接寫代碼就行了,這里只寫下主要的邏輯

showImg(){
    let group = this.data.group
    let height = this.data.height  // 頁面的可視高度
    
    wx.createSelectorQuery().selectAll('.item').boundingClientRect((ret) => {
     ret.forEach((item, index) => {
       if (item.top <= height) { 判斷是否在顯示范圍內
         group[index].show = true // 根據下標改變狀態
       }
     })
     this.setData({
       group
     })
    }).exec()

}
onPageScroll(){ // 滾動事件
    this.showImg()
}

至此,我們完成了一個小程序版的圖片懶加載,只是思維轉變了下,其實并沒有改變實現方式。我們來學些新的東西吧。

節點布局相交狀態

節點相交狀態是啥?它是一個新的API,叫做IntersectionObserver, 本文只講解簡單的使用,了解更多請猛戳沒錯,就是點我

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

里面設計的概念主要有五個,分別為

參照節點:以某參照節點的布局區域作為參照區域,參照節點可以有多個,多個話參照區域取它們的布局區域的交集

目標節點:監聽的目標,只能是一個節點

相交區域:目標節點與參照節點的相交區域

相交比例:目標節點與參照節點的相交比例

閾值:可以有多個,默認為[0], 可以理解為交叉比例,例如[0.2, 0.5]

關于它的API有五個,依次如下

1、createIntersectionObserver([this], [options]),見名知意,創建一個IntersectionObserver實例

2、intersectionObserver.relativeTo(selector, [margins]), 指定節點作為參照區域,margins參數可以放大縮小參照區域,可以包含top、left、bottom、right四項

3、intersectionObserver.relativeToViewport([margin]),指定頁面顯示區域為參照區域

4、intersectionObserver.observer(targetSelector, callback),參數為指定監聽的節點和一個回調函數,目標元素的相交狀態發生變化時就會觸發此函數,callback函數包含一個result,下面再講

5、intersectionObserver.disconnect() 停止監聽,回調函數不會再觸發

然后說下callback函數中的result,它包含的字段為

字段名類型說明
intersectionRatioNumber相交比例
intersectionRectObject相交區域的邊界,包含 left 、 right 、 top 、 bottom 四項
boundingClientRectObject目標節點布局區域的邊界,包含 left 、 right 、 top 、 bottom 四項
relativeRectObject參照區域的邊界,包含 left 、 right 、 top 、 bottom 四項
timeNumber相交檢測時的時間戳

我們主要使用intersectionRatio進行判斷,當它大于0時說明是相交的也就是可見的。

先來波測試題,請說出下面的函數做了什么,并且log函數會執行幾次

1、
wx.createIntersectionObserver().relativeToViewport().observer('.box', (result) => {
     console.log('監聽box組件觸發的函數')   
 })
 
2、
wx.createIntersectionObserver().relativeTo('.box').observer('.item', (result) => {
     console.log('監聽item組件觸發的函數') 
})

3、
wx.createIntersectionObserver().relativeToViewport().observer('.box', (result) => {
    if(result.intersectionRatio > 0){
        console.log('.box組件是可見的') 
    }
})

duang,揭曉答案。

第一個以當前頁面的視窗監聽了.box組件,log會觸發兩次,一次是進入頁面一次是離開頁面

第二個以.box節點的布局區域監聽了.item組件,log會觸發兩次,一次是進入頁面一次是離開頁面

第三個以當前頁面的視窗監聽了.box組件,log只會在節點可見的時候觸發

好了,題也做了,API你也掌握了,相信你已經可以使用IntersectionObserver來實現圖片懶加載了吧,主要邏輯如下

let group = this.data.group // 獲取圖片數組數據
for (let i in this.data.group){   wx.createIntersectionObserver().relativeToViewport().observe('.item-'+ i, (ret) => {
       if (ret.intersectionRatio > 0){
         group[i].show = true 
       }
       this.setData({
         group
       })
     })
}

最后

至此,我們使用兩種方式實現了小程序版本的圖片懶加載,可以發現,使用IntersectionObserver來實現不要太酸爽。

相關推薦:

Javascript實現圖片懶加載插件的方法

用Js實現懶加載和跨域的實現步驟

以上就是什么是懶加載?小程序中圖片懶加載的兩種實現方法的詳細內容,更多請關注php中文網其它相關文章!


小程序是一種不需要下載安裝即可使用的應用,它實現了應用“觸手可及”的夢想,用戶掃一掃或者搜一下即可打開應用。

溫馨提示:喜歡本站的話,請收藏一下本站!

本類教程下載

系統下載排行

在线看毛片视频-国产免费av在线-欧美日韩一区二区三区-国产成人无码av在线播放无广告-亚洲人va欧美va人人爽-国产第一草草-西班牙黄色片-四虎在线网站8848-最新av片免费网站入口-东京热无码中文字幕av专区-日本大人吃奶视频xxxx-欧美精品一区二区三区四区五区-国产片天天弄-国产免费内射又粗又爽密桃视频-欧美爱爱网站-日韩v欧美
  • <li id="86scu"><menu id="86scu"></menu></li>
    <li id="86scu"></li>
    <button id="86scu"></button>
  • <s id="86scu"></s><button id="86scu"><menu id="86scu"></menu></button>
  • 狠狠操狠狠干视频| 国产a级一级片| 中文字幕中文在线| 久久综合色视频| 国产天堂视频在线观看| 天天干天天色天天爽| 亚洲色图欧美自拍| 奇米777在线| 亚洲女人在线观看| 国产成年人在线观看| 婷婷激情小说网| 日本成人性视频| 国产乱子伦精品无码专区| 久久99久久99精品| 色综合久久久久无码专区| 国产精品网站免费| 亚洲中文字幕无码不卡电影| 国产一区视频免费观看| 欧美黄色性生活| 婷婷激情综合五月天| 青青草影院在线观看| 精品丰满人妻无套内射| 欧美激情 国产精品| 青青在线视频免费| 国产大片一区二区三区| 波多野结衣三级在线| 青青青在线视频播放| 国产精品亚洲a| 91精品视频国产| 欧洲美女和动交zoz0z| 久久精品xxx| 91在线视频观看免费| 天堂v在线视频| 韩国日本在线视频| 韩国黄色一级大片| 欧美亚洲精品一区二区| 天堂中文av在线| 国产精品无码人妻一区二区在线| 一区二区三区入口| 欧美这里只有精品| 亚洲精品性视频| 99久久国产综合精品五月天喷水| 欧美国产日韩在线播放| 女女百合国产免费网站| 免费黄色特级片| 国产欧美精品aaaaaa片| 手机看片一级片| 日韩小视频在线播放| 午夜av中文字幕| 无码人妻丰满熟妇区五十路百度| 日韩视频在线观看视频| 91av在线免费播放| 老太脱裤子让老头玩xxxxx| 超碰成人在线免费观看| 亚洲 中文字幕 日韩 无码| 加勒比成人在线| 手机福利在线视频| 不卡中文字幕在线观看| 99免费视频观看| 日本在线xxx| 人妻av无码专区| 一级全黄肉体裸体全过程| 浓精h攵女乱爱av| 大肉大捧一进一出好爽视频| 阿v天堂2018| 国产高清www| 日韩黄色短视频| 欧美成人精品免费| av在线播放天堂| 91.com在线| 777777av| 国产91在线视频观看| 欧美精品一区二区三区三州| 成人免费在线网| 很污的网站在线观看| 成人一对一视频| 国产97在线 | 亚洲| 国产中文字幕二区| 日本一区二区黄色| 毛片毛片毛片毛片毛片毛片毛片毛片毛片 | 91插插插影院| 天天操夜夜操很很操| 精品一区二区三区毛片| 亚洲美女自拍偷拍| 男人添女荫道口女人有什么感觉| 久久久99精品视频| 成人免费观看cn| 少妇性l交大片| 极品粉嫩美女露脸啪啪| 一级做a爱视频| 欧美在线观看黄| 成人免费观看毛片| 国产高清999| r级无码视频在线观看| 99精品视频在线看| 亚洲黄色片免费看| 国产av国片精品| 国内自拍视频一区| av日韩在线看| 久久婷婷国产91天堂综合精品| 天天干天天av| 国产中文字幕二区| 五月六月丁香婷婷| 久久久久人妻精品一区三寸| 午夜福利123| 高清在线观看免费| 天美一区二区三区| 久久久999视频| 亚洲欧美久久久久| 人妻无码久久一区二区三区免费| 欧美xxxxx在线视频| 91视频 - 88av| 亚洲综合色在线观看| 男人的天堂狠狠干| 成年人黄色在线观看| av免费网站观看| 国产玉足脚交久久欧美| 手机av在线免费| 97在线播放视频| 国产女教师bbwbbwbbw| 99日在线视频| 亚州精品一二三区| 国产l精品国产亚洲区久久| 四虎精品欧美一区二区免费| 亚洲欧美日韩一级| 国产成人手机视频| 18禁男女爽爽爽午夜网站免费| 亚洲天堂av免费在线观看| www.涩涩涩| 久久婷婷国产91天堂综合精品| 男女激情无遮挡| 草b视频在线观看| 国产精品视频网站在线观看| 老司机久久精品| 亚洲成人天堂网| 亚洲免费一级视频| 亚洲一区在线不卡| 在线观看免费的av| 艹b视频在线观看| 一道本在线免费视频| 国产一级片自拍| 日本黄色福利视频| 亚洲五月激情网| 可以在线看黄的网站| 樱空桃在线播放| 成人污网站在线观看| 人人妻人人澡人人爽欧美一区| 欧美少妇一区二区三区| 人妻激情另类乱人伦人妻| 欧美一区二区视频在线播放| 五十路熟女丰满大屁股| 野外做受又硬又粗又大视频√| 久久久久久人妻一区二区三区| 国产美女永久无遮挡| 欧美深夜福利视频| 一本大道熟女人妻中文字幕在线 | 一级黄色录像免费看| 欧美久久在线观看| caopor在线视频| 深爱五月综合网| 秋霞无码一区二区| 韩国中文字幕av| 美国av在线播放| 欧美 日韩 激情| 91亚洲一区二区| 国产成人在线免费看| 制服丝袜中文字幕第一页| 欧美一区二区激情| 亚洲精品视频导航| 特级西西人体www高清大胆| 欧美黑人经典片免费观看| 高清一区在线观看| 国内精品视频一区二区三区| 久热免费在线观看| 久久在线中文字幕| 亚洲午夜精品一区| 乱人伦xxxx国语对白| 污视频在线观看免费网站| 日韩欧美一区二| 日本黄色a视频| 亚洲精品一二三四五区| av一区二区三区免费观看| 性欧美videossex精品| 欧美国产日韩激情| 日本女人高潮视频| www.超碰97.com| 国产免费成人在线| 无码专区aaaaaa免费视频| 日韩最新中文字幕| 最新天堂在线视频| 欧美成人免费高清视频| 无罩大乳的熟妇正在播放| www.-级毛片线天内射视视| 九九热99视频| 熟女人妇 成熟妇女系列视频| 青草视频在线观看视频| 天天想你在线观看完整版电影免费| 亚洲36d大奶网| 一级片视频免费观看| 午夜久久久精品|