欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

小程序中監(jiān)聽頁面滾動的幾種方法實例

 更新時間:2022年04月18日 10:58:48   作者:前端小蝸  
這段時間接了一個微信小程序項目,從此打開小程序的新世界大門,下面這篇文章主要給大家介紹了關于小程序中監(jiān)聽頁面滾動的幾種方法,文中通過示例代碼介紹的非常詳細,需要的朋友可以參考下

在工作中我們經常遇到需要監(jiān)聽頁面中元素位置,當元素超出顯示區(qū)域或即將顯示到頁面上,我們就可以做一些動畫或者操作。最常見的操作比如預加載,懶加載,TAB滾動跟隨。

目錄

  • Intersection Observer 在MDN上的介紹
  • 小程序中 IntersectionObserver 的使用

實現效果

在瀏覽器的情況下,我們可以使用 Intersection Observer

下面是Intersection Observer在MDN上的介紹

MDN鏈接

IntersectionObserver接口 (從屬于Intersection Observer API) 提供了一種異步觀察目標元素與其祖先元素或頂級文檔視窗(viewport)交叉狀態(tài)的方法。祖先元素與視窗(viewport)被稱為根(root)。

當一個IntersectionObserver對象被創(chuàng)建時,其被配置為監(jiān)聽根中一段給定比例的可見區(qū)域。一旦IntersectionObserver被創(chuàng)建,則無法更改其配置,所以一個給定的觀察者對象只能用來監(jiān)聽可見區(qū)域的特定變化值;然而,你可以在同一個觀察者對象中配置監(jiān)聽多個目標元素。

簡單來說,就是我們能不能看到想要觀察的對象。

在網頁中,我們很容易就可以用實現Intersection Observer,而在小程序中,我們需要再多掌握一點知識。

IntersectionObserver

小程序中IntersectionObserver的文檔地址

IntersectionObserver 對象,用于推斷某些節(jié)點是否可以被用戶看見、有多大比例可以被用戶看見。

relativeToViewport

指定頁面顯示區(qū)域作為參照區(qū)域之一

Page({
  onLoad: function(){
    wx.createIntersectionObserver().relativeToViewport({bottom: 100}).observe('.target-class', (res) => {
      res.intersectionRatio // 相交區(qū)域占目標節(jié)點的布局區(qū)域的比例
      res.intersectionRect // 相交區(qū)域
      res.intersectionRect.left // 相交區(qū)域的左邊界坐標
      res.intersectionRect.top // 相交區(qū)域的上邊界坐標
      res.intersectionRect.width // 相交區(qū)域的寬度
      res.intersectionRect.height // 相交區(qū)域的高度
    })
  }
})

接受參數 Object margins

用來擴展(或收縮)參照節(jié)點布局區(qū)域的邊界

屬性類型默認值必填說明
leftnumber 節(jié)點布局區(qū)域的左邊界
rightnumber 節(jié)點布局區(qū)域的右邊界
topnumber 節(jié)點布局區(qū)域的上邊界
bottomnumber 節(jié)點布局區(qū)域的下邊界

observe(string targetSelector, function callback)

參數

(targetSelector:string,callback:function)

Object res

屬性類型說明
idstring節(jié)點 ID
datasetRecord.<string, any>節(jié)點自定義數據屬性
intersectionRationumber相交比例
intersectionRectObject相交區(qū)域的邊界
boundingClientRectObject目標邊界
relativeRectObject參照區(qū)域的邊界
timenumber相交檢測時的時間戳

小程序中監(jiān)聽頁面的其他方法

page-meta

頁面屬性配置節(jié)點,用于指定頁面的一些屬性、監(jiān)聽頁面事件。只能是頁面內的第一個節(jié)點??梢耘浜?nbsp;navigation-bar 組件一同使用。

scroll-view

可滾動視圖區(qū)域。使用豎向滾動時,需要給 scroll-view一個固定高度,通過 WXSS 設置 height。組件屬性的長度單位默認為px。

總結

在小程序中,我們可以用 IntersectionObserver ,來監(jiān)聽頁面的元素與頁面交叉的距離,如此一來我們便可以在小程序中實現懶加載,預加載,動畫等效果。

我們也可以用 page-meta 和 scroll-view 來實現滾動監(jiān)聽,具體需要結合實際場景。

到此這篇關于小程序中監(jiān)聽頁面滾動的幾種方法的文章就介紹到這了,更多相關小程序監(jiān)聽頁面滾動內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • 微信小程序學習筆記之跳轉頁面、傳遞參數獲得數據操作圖文詳解

    微信小程序學習筆記之跳轉頁面、傳遞參數獲得數據操作圖文詳解

    這篇文章主要介紹了微信小程序學習筆記之跳轉頁面、傳遞參數獲得數據操作,結合實例形式分析了微信小程序基于navigator組件的頁面跳轉及數據傳遞相關操作技巧,并結合圖文形式進行詳細說明,需要的朋友可以參考下
    2019-03-03
  • 基于Javascript實現彈出頁面效果

    基于Javascript實現彈出頁面效果

    彈出層效果是一個很實用的功能,很多網站都采用了這種方式實現登錄和注冊,下面小編通過本文給大家分享具體實現代碼,對js彈出頁面效果相關知識感興趣的朋友一起學習吧
    2016-01-01
  • 跟我學習javascript的隱式強制轉換

    跟我學習javascript的隱式強制轉換

    跟我學習javascript的隱式強制轉換,感興趣的小伙伴們可以學習一下
    2015-11-11
  • 微信小程序合法域名配置方法

    微信小程序合法域名配置方法

    這篇文章主要介紹了微信小程序合法域名配置,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2019-05-05
  • javascript獲取四位數字或者字母的隨機數

    javascript獲取四位數字或者字母的隨機數

    這篇文章主要介紹了javascript獲取四位數字或者字母的隨機數,需要的朋友可以參考下
    2015-01-01
  • JS動態(tài)添加Table的TR,TD實現方法

    JS動態(tài)添加Table的TR,TD實現方法

    這篇文章主要介紹了JS動態(tài)添加Table的TR,TD實現方法,涉及js針對Table中TR、TD節(jié)點的操作技巧,具有一定參考借鑒價值,需要的朋友可以參考下
    2015-01-01
  • Omi v1.0.2發(fā)布正式支持傳遞javascript表達式

    Omi v1.0.2發(fā)布正式支持傳遞javascript表達式

    這篇文章主要介紹了Omi v1.0.2發(fā)布正式支持傳遞javascript表達式,非常不錯,具有參考借鑒價值,需要的朋友可以參考下
    2017-03-03
  • window.open以post方式將內容提交到新窗口

    window.open以post方式將內容提交到新窗口

    最近在做web項目,碰到需要跨頁面?zhèn)鬟f參數的功能,就是那種需要把當前頁面的內容帶到新開的子窗體中,以前的做法是傳一個id過去,然后在新窗口中去讀數據庫的內容;比較有意思的是直接通過調用form的submit方法不能觸發(fā)onsubmit事件,查看了幫助文檔,必須手動的觸發(fā),否則只能看到頁面刷新而沒有打開新窗口
    2012-12-12
  • js中toString()與valueOf()的使用

    js中toString()與valueOf()的使用

    tostring 和 valueOf 函數是解決值的顯示和運算的問題,本文主要介紹了js中toString()與valueOf()的使用,文中通過示例代碼介紹的非常詳細,需要的朋友們下面隨著小編來一起學習學習吧
    2023-06-06
  • js實現的鼠標滾輪滾動切換頁面效果(類似360默認頁面滾動切換效果)

    js實現的鼠標滾輪滾動切換頁面效果(類似360默認頁面滾動切換效果)

    這篇文章主要介紹了js實現的鼠標滾輪滾動切換頁面效果,類似360默認頁面滾動切換效果.涉及JavaScript響應鼠標事件動態(tài)變換頁面元素的相關技巧,需要的朋友可以參考下
    2016-01-01

最新評論