亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

React Hooks常用鉤子及基本原理解讀

 更新時(shí)間:2023年10月26日 09:04:14   作者:綠足  
這篇文章主要介紹了React Hooks常用鉤子及基本原理,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教

一. 簡(jiǎn)述

在以往的react16.8前, 我們React組件創(chuàng)建方式基本包含兩種方式: 類組件, 純函數(shù)組件

React 團(tuán)隊(duì)希望組件最佳寫(xiě)法應(yīng)該是函數(shù),而不是類。

然而常規(guī)的純函數(shù)組件有以下特點(diǎn):

  • 沒(méi)有狀態(tài)
  • 沒(méi)有生命周期
  • 沒(méi)有 this

因存在如上特點(diǎn),使得純函數(shù)組件只能做UI展示的功能, 涉及到狀態(tài)的管理與切換就不得不用到類組件或這redux。

但因?yàn)楹?jiǎn)單的頁(yè)面也是用類組件,同時(shí)要繼承一個(gè)React實(shí)例,使得代碼會(huì)顯得很重。

‘Hooks’ 單詞意思為:鉤子。

React Hooks 意思是:組件盡量寫(xiě)成純函數(shù),如果需要外部功能和副作用,就用鉤子把外部代碼“鉤”進(jìn)來(lái)。

React Hooks常用鉤子有如下四種:

  • useState()
  • useContext()
  • useReducer()
  • useEffect()

使用hooks 我們會(huì)發(fā)現(xiàn)沒(méi)有了繼承,渲染邏輯,生命周期等, 代碼看起來(lái)更加的輕便簡(jiǎn)潔了。

React 約定,鉤子一律使用 use 前綴命名 (自定義鉤子都命名為:useXXXX)

二. 常用舉例及原理分析

useState 狀態(tài)鉤子

官方示例:

import React, {useState} from 'react'
const AddCount = () => {
  const [ count, setCount ] = useState(0)
  const addcount = () => {
    let newCount = count
    setCount(newCount+=1)
  } 
  return (
    <>
      <p>{count}</p>
      <button onClick={addcount}>count++</button>
    </>
  )
}

原理:

// 我們實(shí)現(xiàn)一個(gè)簡(jiǎn)易版的useState
let memoizedStates = [ ]  // 多個(gè)useState 時(shí)需要使用數(shù)組來(lái)存
let index = 0
function useState (initialState) {
   memoizedStates[index] = memoizedStates[index] || initialState
   let currentIndex = index;
   function setState (newState) {
      memoizedStates[currentIndex] = newState
      render()
   }
   return [memoizedStates[index++], setState]
}

useContext 共享狀態(tài)鉤子

該鉤子的作用是,在組件之間共享狀態(tài)。

可以解決react逐層通過(guò)Porps傳遞數(shù)據(jù)。

import React,{ useContext } from 'react'
const ShareContext= () => {
  const AppContext = React.createContext({})
  const A =() => {
    const { name } = useContext(AppContext)
    return (
        <p>我是A組件的名字{name}<span>我是A的子組件{name}</span></p>
    )
}
const B =() => {
  const { name } = useContext(AppContext)
  return (
      <p>我是B組件的名字{name}</p>
  )
}
  return (
    <AppContext.Provider value={{name: 'hook測(cè)試'}}>
    <A/>
    <B/>
    </AppContext.Provider>
  )
}
export default ShareContext

useContext(context) 是針對(duì) context (上下文) 提出的api。

它接受React.createContext()的返回結(jié)果作為參數(shù)(也就是context對(duì)象并返回最近的context)。

使用useContext將不再需要Provider 和 Consumer。

當(dāng)最近的context更新時(shí),那么使用該context的hook將會(huì)重新渲染。

useReducer(): Action 鉤子

React本身不提供狀態(tài)管理。

而useReducer() 提供了狀態(tài)管理。

其基本原理是通過(guò)用戶在頁(yè)面中發(fā)起action, 從而通過(guò)reducer方法來(lái)改變state, 從而實(shí)現(xiàn)頁(yè)面和狀態(tài)的通信。

import React,{useReducer} from 'react'

const MyReducer= () => {
const reducer = (state, action) =>  {
 if(action.type === ''add){
  return {
  ...state,
  count: state.count +1,
  }
 }else {
   return state
  }
 }
const addcount = () => { 
  dispatch({
    type: 'add'
  })
 }
const [state, dispatch] = useReducer(reducer, {count: 0})
return (
<>
<p>{state.count}</p>
<button onClick={addcount}>count++</button>
</>
)
}
export default MyReducer

使用useReducer() 代替了Redux的功能, 但useReducer 無(wú)法提供中間件等功能。

useEffect(): 副作用鉤子

React常規(guī)開(kāi)發(fā)中,我們習(xí)慣將一些處理副作用的操作,如:異步請(qǐng)求等 放在特定的生命周期中。

useEffect 則是為函數(shù)組件提供了副作用的鉤子。

useEffect() : 接收兩個(gè)參數(shù), 第一個(gè)是進(jìn)行的異步操作, 第二個(gè)是數(shù)組,用來(lái)給出Effect的依賴項(xiàng)。

第二個(gè)參數(shù)(數(shù)組)發(fā)生變化, ==useEffect()==就會(huì)執(zhí)行。

第二項(xiàng)不填時(shí), useEffect() 會(huì)在每次組件渲染時(shí)執(zhí)行。

import React, { useState, useEffect } from 'react'

const AsyncPage = ({name}) => {
const [loading, setLoading] = useState(true)
const [person, setPerson] = useState({})
//  useEffect 類似compomnetDidMount 初始化會(huì)執(zhí)行,更新時(shí)會(huì)執(zhí)行
  useEffect(() => {
    setLoading(true)
    setTimeout(()=> {
      setLoading(false)
      setPerson({name})
    },3000)
  },[name])
  return (
    <div>
      {loading?<p>Loading...</p>:<p>{person.name}</p>}
    <div/>
  )
}

const PersonPage = () =>{
  const [state, setState] = useState('')
  const changeName = (name) => {
    setState(name)
  }
  return (
    <>
      <AsyncPage name={state}/>
      <button onClick={() => {changeName('名字1')}}>名字1</button>
      <button onClick={() => {changeName('名字2')}}>名字2</button>
    </>
  )
}

export default PersonPage 

創(chuàng)建自己的Hooks

有時(shí)候我們需要?jiǎng)?chuàng)建自己想要的Hooks, 來(lái)滿足更便捷的開(kāi)發(fā)。

import React, { useState, useEffect } from 'react'

const usePerson = (name) => {
const [loading, setLoading] = useState(true)
const [person, setPerson] = useState({})

  useEffect(() => {
    setLoading(true)
    setTimeout(()=> {
      setLoading(false)
      setPerson({name})
    },2000)
  },[name])
  return [loading,person]
}

const AsyncPage = ({name}) => {
  const [loading, person] = usePerson(name)
    return (
      <div>
        {loading?<p>Loading...</p>:<p>{person.name}</p>}
      </div>
    )
  }

const PersonPage = () =>{
  const [state, setState]=useState('')
  const changeName = (name) => {
    setState(name)
  }
  return (
    <div>
      <AsyncPage name={state} />
      <button onClick={() => {changeName('名字1')}}>名字1</button>
      <button onClick={() => {changeName('名字2')}}>名字2</button>
    </div>
  )
}

export default PersonPage 

上面自定義了一個(gè)Hooks, 它接受一個(gè)字符串, 返回一個(gè)數(shù)組, 數(shù)組中的兩個(gè)狀態(tài)在使用usePerson() 時(shí), 會(huì)根據(jù)傳入的不同反而返回不同的狀態(tài)。

React Hooks 概要及未來(lái)

根據(jù)官方文檔的說(shuō)法:

完全可選

  • 100%向后兼容 (Hook 不會(huì)含任何破壞性改動(dòng))
  • 現(xiàn)在可用 (Hook 已發(fā)布于 v16.8.0)
  • 沒(méi)有計(jì)劃從React中移除class
  • Hook不會(huì)影響對(duì)React概念的理解 (Hook 為React提供了相關(guān)API:props, state,context, refs以及生命周期)

總結(jié)

以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • React router基礎(chǔ)使用方法詳解

    React router基礎(chǔ)使用方法詳解

    這篇文章主要介紹了React router基礎(chǔ)使用方法,React Router是React生態(tài)系統(tǒng)中最受歡迎的第三方庫(kù)之一,近一半的React項(xiàng)目中使用了React Router,下面就來(lái)看看如何在React項(xiàng)目中使用
    2023-04-04
  • React中useEffect函數(shù)的使用詳解

    React中useEffect函數(shù)的使用詳解

    useEffect是React中的一個(gè)鉤子函數(shù),用于處理副作用操作,這篇文章主要為大家介紹了React中useEffect函數(shù)的具體用法,希望對(duì)大家有所幫助
    2023-08-08
  • 詳解React?如何防止?XSS?攻擊論$$typeof?的作用

    詳解React?如何防止?XSS?攻擊論$$typeof?的作用

    這篇文章主要介紹了詳解React?如何防止?XSS?攻擊論$$typeof?的作用,文章圍繞主題展開(kāi)詳細(xì)的內(nèi)容介紹,具有一定的參考價(jià)值,需要的小伙伴可以參考一下
    2022-07-07
  • 在React中如何優(yōu)雅的處理事件響應(yīng)詳解

    在React中如何優(yōu)雅的處理事件響應(yīng)詳解

    這篇文章主要給大家介紹了關(guān)于在React中如何優(yōu)雅處理事件響應(yīng)的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面跟著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧。
    2017-07-07
  • React Navigation 使用中遇到的問(wèn)題小結(jié)

    React Navigation 使用中遇到的問(wèn)題小結(jié)

    本篇文章主要介紹了React Navigation 使用中遇到的問(wèn)題小結(jié),主要是安卓和iOS中相對(duì)不協(xié)調(diào)的地方,特此記錄,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2018-05-05
  • react native圖片解析流程詳解

    react native圖片解析流程詳解

    這篇文章主要為大家介紹了react native圖片解析流程詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-01-01
  • React Hooks的深入理解與使用

    React Hooks的深入理解與使用

    這篇文章主要介紹了React Hooks的深入理解與使用,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2018-11-11
  • 可定制react18 input otp 一次性密碼輸入組件

    可定制react18 input otp 一次性密碼輸入組件

    這篇文章主要為大家介紹了可定制react18 input otp 一次性密碼輸入組件,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-10-10
  • React實(shí)現(xiàn)評(píng)論的添加和刪除

    React實(shí)現(xiàn)評(píng)論的添加和刪除

    這篇文章主要為大家詳細(xì)介紹了React實(shí)現(xiàn)評(píng)論的添加和刪除,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2020-10-10
  • React無(wú)限滾動(dòng)加載列表組件的封裝實(shí)現(xiàn)

    React無(wú)限滾動(dòng)加載列表組件的封裝實(shí)現(xiàn)

    無(wú)限下拉加載技術(shù)是用戶在大量成塊的內(nèi)容面前一直滾動(dòng)查看,本文主要介紹了React無(wú)限滾動(dòng)加載列表組件的封裝實(shí)現(xiàn),具有一定的參考價(jià)值,感興趣的可以了解一下
    2023-12-12

最新評(píng)論