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

react中useRef的應(yīng)用使用詳解

 更新時(shí)間:2023年05月26日 08:18:13   作者:mikumikugo  
這篇文章主要介紹了react中useRef的應(yīng)用使用詳解的相關(guān)資料,需要的朋友可以參考下

何為useRef

useRef是隨著react函數(shù)式組件發(fā)展而來(lái)的,是react眾多官方hook中的一個(gè),調(diào)用useRef可以返回一個(gè)伴隨這組件整個(gè)聲明周期不發(fā)生改變的對(duì)象,這個(gè)對(duì)象常見(jiàn)的用途有兩個(gè):

  • 用于綁定dom元素,從而實(shí)現(xiàn)對(duì)dom元素的操作
  • 用于保存不希望隨著組件重新渲染而改變的值,如定時(shí)器

在項(xiàng)目中的應(yīng)用

我在做自己的網(wǎng)站時(shí)遇到過(guò)一些場(chǎng)景,實(shí)現(xiàn)效果與預(yù)想中的不一致,讓我頭大了好一陣子,所幸最終都得到了解決,為了在以后能夠回來(lái)看一下,同時(shí)記錄學(xué)習(xí)過(guò)程中的一些知識(shí)點(diǎn),現(xiàn)將這兩個(gè)場(chǎng)景記錄如下。

一、編寫(xiě)自己的防抖函數(shù)

在編寫(xiě)登錄注冊(cè)功能時(shí),需要對(duì)用戶輸入的信息進(jìn)行校驗(yàn),包括前端的校驗(yàn)以及和后端通信的校驗(yàn),如果只是前端的校驗(yàn)還好,如果在用戶輸入的信息每次發(fā)生變化都去和服務(wù)器通信校驗(yàn)的話,大量的http請(qǐng)求會(huì)對(duì)服務(wù)器造成壓力,所以我希望對(duì)這些行為進(jìn)行防抖處理。

useDebounce.ts

import { useEffect, useRef } from "react"
export const useDebounce = (f:Function,delay:number)=>{
    //使用useRef保存計(jì)時(shí)器,以此確保在組件更新時(shí)始終是同一個(gè)計(jì)時(shí)器,而不是重新創(chuàng)建
    const {current} = useRef<{timmer:any}>({timmer:null})
    useEffect(()=>{
        return ()=>{
            //組件銷毀時(shí)清除計(jì)時(shí)器
            clearTimeout(current.timmer)
        }
    },[])
    return function(...args:any[]){
        //如果計(jì)時(shí)器存在,則清除該計(jì)時(shí)器
        if(current.timmer){
            clearTimeout(current.timmer)
        }
        //重新賦值計(jì)時(shí)器,并在計(jì)時(shí)結(jié)束后執(zhí)行回調(diào)函數(shù)
        current.timmer = setTimeout(() => {
            f.apply(useDebounce,args)
        }, delay);
    }
}

這里我將防抖函數(shù)寫(xiě)成了一個(gè)自定義的hook,也是寫(xiě)的第一個(gè)hook,調(diào)用時(shí)需要傳入兩個(gè)參數(shù),第一個(gè)參數(shù)是需要進(jìn)行防抖處理的函數(shù),第二個(gè)參數(shù)是防抖的延時(shí)時(shí)間,hook返回值是經(jīng)過(guò)防抖處理的函數(shù)。

二、解決回調(diào)函數(shù)中獲取不到最新state值的問(wèn)題

在實(shí)現(xiàn)獲取評(píng)論列表時(shí),我希望每次只獲取一定數(shù)量的評(píng)論,當(dāng)用戶瀏覽到頁(yè)面底端時(shí)再獲取新的評(píng)論,在實(shí)現(xiàn)過(guò)程中我用到了intersectionObserverAPI,并在它的回調(diào)函數(shù)中引用了組件中的一些state。

當(dāng)我直接在useEffect副作用函數(shù)中進(jìn)行綁定監(jiān)聽(tīng)的元素時(shí),發(fā)現(xiàn)回調(diào)函數(shù)中的state值一直保持observer對(duì)象創(chuàng)建時(shí)的值,經(jīng)過(guò)查詢相關(guān)資料,得知這可能是因?yàn)殚]包的影響。解決辦法是使用useRef創(chuàng)建一個(gè)對(duì)象用于保存observer對(duì)象,并在相關(guān)state值發(fā)生變化后釋放原來(lái)的observer對(duì)象,創(chuàng)建一個(gè)新的observer對(duì)象,并重新綁定要監(jiān)聽(tīng)的元素。

//指向要監(jiān)聽(tīng)的元素
const bref = useRef(null)
//保存observer對(duì)象
const observer = useRef<any>()
 
//每當(dāng)comments變化,都會(huì)重新創(chuàng)建一個(gè)observer對(duì)象,其回調(diào)函數(shù)中引用的就是最新的state值
   useEffect(() => {
    let c = new IntersectionObserver((entries) => {
      if (entries[0].intersectionRatio > 0) {
        if (page * pageNum <= count) {
          const fd = new FormData()
          fd.append('articleId', param.articleid)
          fd.append('page', page + 1)
          fd.append('pageNum', pageNum)
          http({ url: '/comment/comments', options: { method: 'POST', body: fd } }).then(res => {
            if (count !== res.count) {
              setcount(res.res.count)
            }

            setpage(page + 1)
            setcomments([...comments, ...res.res.rows])
          })
        }

      }
    })
  //取消舊的監(jiān)聽(tīng)
    if (observer.current) {
      observer.current.unobserve(bref.current)
    }
//保存新的observer對(duì)象,并建立新的監(jiān)聽(tīng)
    observer.current = c
    observer.current.observe(bref.current)
  }, [comments])

實(shí)踐出真知,在項(xiàng)目中發(fā)現(xiàn)問(wèn)題,尋找解決問(wèn)題的方法,大江不止兮水長(zhǎng)流,不斷積累,豐富閱歷,提升能力。

到此這篇關(guān)于react中useRef的應(yīng)用使用詳解的文章就介紹到這了,更多相關(guān)react中useRef的應(yīng)用內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • React中classnames庫(kù)使用示例

    React中classnames庫(kù)使用示例

    這篇文章主要為大家介紹了React中classnames庫(kù)使用示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-10-10
  • React 項(xiàng)目遷移 Webpack Babel7的實(shí)現(xiàn)

    React 項(xiàng)目遷移 Webpack Babel7的實(shí)現(xiàn)

    這篇文章主要介紹了React 項(xiàng)目遷移 Webpack Babel7的實(shí)現(xiàn),小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2018-09-09
  • 在react中使用windicss的問(wèn)題

    在react中使用windicss的問(wèn)題

    這篇文章主要介紹了在react中使用windicss的問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-10-10
  • React報(bào)錯(cuò)Type '() => JSX.Element[]' is not assignable to type FunctionComponent

    React報(bào)錯(cuò)Type '() => JSX.Element[]&apos

    這篇文章主要為大家介紹了React報(bào)錯(cuò)Type '() => JSX.Element[]' is not assignable to type FunctionComponent解決,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-12-12
  • react中使用echarts,并實(shí)現(xiàn)tooltip循環(huán)輪播方式

    react中使用echarts,并實(shí)現(xiàn)tooltip循環(huán)輪播方式

    這篇文章主要介紹了react中使用echarts,并實(shí)現(xiàn)tooltip循環(huán)輪播方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-01-01
  • React?高德地圖進(jìn)京證路線規(guī)劃問(wèn)題記錄(匯總)

    React?高德地圖進(jìn)京證路線規(guī)劃問(wèn)題記錄(匯總)

    這篇文章主要介紹了React高德地圖進(jìn)京證路線規(guī)劃問(wèn)題小記,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),感興趣的朋友跟隨小編一起看看吧
    2024-08-08
  • React Router 5.1.0使用useHistory做頁(yè)面跳轉(zhuǎn)導(dǎo)航的實(shí)現(xiàn)

    React Router 5.1.0使用useHistory做頁(yè)面跳轉(zhuǎn)導(dǎo)航的實(shí)現(xiàn)

    本文主要介紹了React Router 5.1.0使用useHistory做頁(yè)面跳轉(zhuǎn)導(dǎo)航的實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-11-11
  • 詳解如何給React-Router添加路由頁(yè)面切換時(shí)的過(guò)渡動(dòng)畫(huà)

    詳解如何給React-Router添加路由頁(yè)面切換時(shí)的過(guò)渡動(dòng)畫(huà)

    這篇文章主要介紹了詳解如何給React-Router添加路由頁(yè)面切換時(shí)的過(guò)渡動(dòng)畫(huà),小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2019-04-04
  • 如何利用React實(shí)現(xiàn)圖片識(shí)別App

    如何利用React實(shí)現(xiàn)圖片識(shí)別App

    圖片識(shí)別這個(gè)功能在很多app中都有,下面這篇文章主要給大家介紹了關(guān)于如何利用React實(shí)現(xiàn)圖片識(shí)別App的相關(guān)資料,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2022-01-01
  • react組件實(shí)例屬性state詳解

    react組件實(shí)例屬性state詳解

    這篇文章主要介紹了react組件實(shí)例屬性state,有狀態(tài)state的組件稱作復(fù)雜組件,沒(méi)有狀態(tài)的組件稱為簡(jiǎn)單組件,狀態(tài)里存儲(chǔ)數(shù)據(jù),數(shù)據(jù)的改變驅(qū)動(dòng)頁(yè)面的展示,本文結(jié)合實(shí)例代碼給大家詳細(xì)講解,需要的朋友可以參考下
    2023-02-02

最新評(píng)論