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

React hooks使用方法全面匯總

 更新時間:2022年10月14日 08:54:58   作者:愛思考的豬  
這篇文章主要介紹了react hooks實(shí)現(xiàn)原理,文中給大家介紹了useState dispatch函數(shù)如何與其使用的Function Component進(jìn)行綁定,實(shí)例代碼給大家介紹的非常詳細(xì),需要的朋友可以參考下

1. 前言

react16.8推出hooks更好的支持函數(shù)組件,使用函數(shù)組件更容易進(jìn)行代碼的復(fù)用,拓展性更強(qiáng)。

2. useState

useState類似于class組件的state功能,用于更新視圖

import React, { Component, useState } from 'react';
export default function Hello() {
  const [count, setCount] = useState(0); //設(shè)置默認(rèn)值為0
  return <div>
    {count}
    <button onClick={()=>setCount(count + 1)}>增加</button>
  </div>
}
//useState還可以使用函數(shù)進(jìn)行賦值
 const [count, setCount] = useState(()=>0); //設(shè)置默認(rèn)值為0

3. useEffect

useEffect接受兩個參數(shù),第一個參數(shù)是要執(zhí)行的回調(diào)函數(shù),第二個參數(shù)是依賴的參數(shù),如下面的例子里只有當(dāng)count發(fā)生變化的時候才會打印count,當(dāng)?shù)诙€參數(shù)為空數(shù)組的時候,組件在渲染完成后會執(zhí)行一次,第二個參數(shù)不傳遞的時候每次渲染都會執(zhí)行

export default function Hello() {
  const [count, setCount] = useState(() => 0); //設(shè)置默認(rèn)值為0
  // useEffect
  useEffect(() => {
  }, [count])
  return <div>
    {count}
    <button onClick={() => setCount(count + 1)}>增加</button>
  </div>
}

帶有返回值的useEffect用于清除執(zhí)行過程中的副作用

  useEffect(()=>{
    const timer = setInterval(() => {
      console.log(count);
    }, 1000);
    window.addEventListener('resize',handleResize);
    return function(){
      clearInterval(timer);
      window.removeEventListener('resize',handleResize);
    }
  }, [count])

如果每次執(zhí)行useEffect都定義一個定時器,那定時器會越來越多,通過在返回函數(shù)中清除定時器取消這個副作用。useEffect返回函數(shù)的執(zhí)行時機(jī)是下一次useEffect執(zhí)行之前。

利用這一點(diǎn)可以實(shí)現(xiàn)防抖和節(jié)流函數(shù)

4. useLayoutEffect

dom渲染之前的useEffect: useLayoutEffect =》 dom渲染 =》useLayout

export default function Hello (props){
  const [count, setCount]  = useState(0);
  useEffect(()=>{
    console.log('useEffect');
  },[count]);
  useLayoutEffect(()=>{
    console.log('useLayoutEffect');
  },[count])
  return <div>
    {count}
    <button onClick={()=> setCount(count+1)}>增加</button>;
  </div>
}

使用useEffect和useLayoutEffect去更新視圖狀態(tài)會產(chǎn)生不同的效果,useEffect會有一個狀態(tài)到另一個狀態(tài)的過程(閃動效果),useLayoutEffect直接渲染最終狀態(tài)

5. useMemo

useMemo的作用就是緩存,減少代碼的執(zhí)行次數(shù)。

下面的代碼點(diǎn)擊按鈕count狀態(tài)發(fā)生變化,整個Hello函數(shù)體內(nèi)的代碼都會執(zhí)行,每次點(diǎn)擊按鈕都會打印str的值

export default function Hello (props){
  const [count, setCount]  = useState(0);
  const [str, setStr] = useState('hello hooks!');
  useEffect(()=>{
    console.log('useEffect');
  },[count]);
  console.log('str'); //每次渲染都會執(zhí)行
  return <div>
    {count}
    {str}
    <button onClick={()=> setCount(count+1)}>增加</button>
  </div>
}

使用useMemeo進(jìn)行緩存,當(dāng)str發(fā)生變化的時候再執(zhí)行打印語句

useMemo(()=>{
  console.log(str);
},[str])

useMemo還可以用來緩存函數(shù)

export default function Hello (props){
  const [count, setCount]  = useState(0);
  const [str, setStr] = useState('hello hooks!');
  useEffect(()=>{
    console.log('useEffect');
  },[count]);
  // 使用useMemo緩存函數(shù)
  const hanldeClick = useMemo(()=>{
    return function(){
      console.log(count);
    };
  },[count]);
  return <div>
    {count}
    {str}
    <button onClick={()=> setCount(count+1)}>增加</button>
    <button onClick={hanldeClick}>測試</button>
  </div>
}

6. useCallback

useCallback的功能是緩存函數(shù),取的是useMemo的運(yùn)行結(jié)果

  const handleClick = useMemo(()=>{
    return function(){
      console.log(count);
    };
  },[count]);
  const handleClick = useCallback(()=>{
    console.log(count);
  },[count])

上面兩個實(shí)現(xiàn)的功能是一樣的,在平時的開發(fā)中要盡量使用useMemo去緩存函數(shù)

7. useRef

  • 獲取元素dom ref.current
  • 緩存數(shù)據(jù)

使用useRef獲取元素

export default function Hello(props) {
  const ref = useRef(null);
  useEffect(() => {
    console.log(ref.current); // <input id='input'>
  })
  return <div>
    <input ref={ref} id="input" />
  </div>
}

使用useRef保存數(shù)據(jù),當(dāng)ref.current發(fā)生變化的時候視圖不會重新渲染

export default function Hello(props) {
  const ref = useRef(null);
  useEffect(() => {
    ref.current = 'hello hooks!';
  });
  return <div>
    <span> {ref.current}</span>
  </div>
}

8. useReducer

useReducer用于更新復(fù)雜的state提升渲染性能,使用方法與redux類似。與redux的區(qū)別是redux管理的是全局的數(shù)據(jù)做數(shù)據(jù)共享,useReducer是useState的替代方案,只管理單個組件的狀態(tài)。

onst reducer = (state, action) => {
  switch (action.name) {
    case 'increment': return { count: state.count + 1 };
    case 'decrement': return { count: state.count - 1 };
    default: return state;
  }
};
const initState = { count: 0 };
export default function Hello() {
  const [state, dispatch] = useReducer(reducer, initState)
  return <div>
    <span> {state.count}</span>
    <button onClick={() => dispatch({ name: 'increment' })}>增加</button>
    <button onClick={() => dispatch({ name: 'decrement' })}>減少</button>
  </div>
}

9. useContext

useContext用來解決props層層傳遞,嵌套很深的問題。

export default function Father() {
  const [count, setCount] = useState(0);
  const handleClick = useCallback(() => {
    setCount(count + 1);
  }, [count]);
  return <div>
    {count}
    <button onClick={() => handleClick()}>增加</button>
    <MyContext.Provider value={{ count }}>
      <Children />
    </MyContext.Provider>
  </div>
};
function Children() {
  const context = useContext(MyContext);
  return <div>
    父組件的count: {context.count}
  </div>
};

10. memo

在calss組件中通過對比props,子組件接收的props發(fā)生變化的時候才進(jìn)行更新渲染,在函數(shù)組件中沒有識別props的能力,當(dāng)父組件重新渲染的時候子組件也會重新渲染,在使用memo包裹后只有props發(fā)生變化的時候才會重新渲染。memo的功能類似于calss組件對pureComponent對props進(jìn)行了淺比較。

export default function Father() {
 const [count, setCount] = useState(0);
 const [str, setStr] = useState('hello hooks!');
 return <div>
   {count}
   {str}
   <button onClick={() => setCount(count + 1)}>增加count</button>
   <button onClick={() => setStr(str + 1)}>修改str</button>
   <Children count={count} />
 </div>
};
const Children = React.memo(function Children(props) {
 console.log('子組件渲染');
 return <div>
   子組件: {props.count}
 </div>
}
);

上面的例子中,count變化的時候子組件渲染更新,str變化的時候子組件不重新渲染。

到此這篇關(guān)于React hooks使用方法全面匯總的文章就介紹到這了,更多相關(guān)React hooks內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • react簡單實(shí)現(xiàn)防抖和節(jié)流

    react簡單實(shí)現(xiàn)防抖和節(jié)流

    在日常開發(fā)中,我們經(jīng)常會有防抖和節(jié)流的需要,可以減小服務(wù)器端壓力,提升用戶體驗(yàn),本文就詳細(xì)的介紹了react簡單實(shí)現(xiàn)防抖和節(jié)流,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2022-05-05
  • React更新渲染原理深入分析

    React更新渲染原理深入分析

    什么是re-render(重新渲染)?哪些是必要的re-render?哪些是非必要的re-render?如果你對這些問題還不是很明白,那么可以在這篇文章中找到答案
    2022-12-12
  • Create?react?app修改webapck配置導(dǎo)入文件alias

    Create?react?app修改webapck配置導(dǎo)入文件alias

    這篇文章主要為大家介紹了Create?react?app修改webapck配置導(dǎo)入文件alias,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-12-12
  • 想用好React的你必須要知道的一些事情

    想用好React的你必須要知道的一些事情

    現(xiàn)在最熱門的前端框架,毫無疑問是 React 。下面這篇文章主要給大家分享了關(guān)于想用好React的你必須要知道的一些事情,文中介紹的非常詳細(xì),對大家具有一定參考學(xué)習(xí)價值,需要的朋友們下面來一起看看吧。
    2017-07-07
  • React?redux?原理及使用詳解

    React?redux?原理及使用詳解

    這篇文章主要為大家介紹了React?redux?原理及使用詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-11-11
  • react+tsx中使用better-scroll詳解

    react+tsx中使用better-scroll詳解

    這篇文章主要介紹了react+tsx中使用better-scroll,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-09-09
  • React Native 環(huán)境搭建的教程

    React Native 環(huán)境搭建的教程

    本篇文章主要介紹了React Native 環(huán)境搭建的教程,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-08-08
  • 阿里低代碼框架lowcode-engine自定義設(shè)置器詳解

    阿里低代碼框架lowcode-engine自定義設(shè)置器詳解

    這篇文章主要為大家介紹了阿里低代碼框架lowcode-engine自定義設(shè)置器示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-02-02
  • React.js入門實(shí)例教程之創(chuàng)建hello world 的5種方式

    React.js入門實(shí)例教程之創(chuàng)建hello world 的5種方式

    React 是近期非常熱門的一個前端開發(fā)框架。應(yīng)用非常廣泛,接下來通過本文給大家介紹React.js入門實(shí)例教程之創(chuàng)建hello world 的5種方式 ,需要的朋友參考下吧
    2016-05-05
  • React實(shí)現(xiàn)二級聯(lián)動效果(樓梯效果)

    React實(shí)現(xiàn)二級聯(lián)動效果(樓梯效果)

    這篇文章主要為大家詳細(xì)介紹了React實(shí)現(xiàn)二級聯(lián)動效果,樓梯效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-09-09

最新評論