ReactHooks专题-useReducer

链接: 文档链接.

useReducer

很多人看到useReducer的第一反应应该是redux的替代品,其实并不是;
useReducer仅仅是useState的一种替代方案;

  • 在某些场景下,如果state的处理逻辑比较复杂,我们可以通过useReducer来对其进行拆分;
  • 或者这次修改的state需要依赖之前的state时,也可以使用;

useReducer的基本使用

function counterReducer (state,action){
  switch (action.type) {
    case "increment":
      return {...state,counter:state.counter+action.speed}
      case "decrement":
        return {...state,counter:state.counter-action.speed}
    default:
      return state;
  }
}
export default function App() {
  let [state,dispath]=useReducer(counterReducer,{counter:96})
  return (
    <div>
      <h2>你好-{state.counter}</h2>
      <button onClick={()=>{
        dispath({type:'increment',speed:2})
      }}>+</button>
      <button onClick={()=>{
        dispath({type:'decrement',speed:1})
      }}>-</button>
    </div>
  );
}

拆分useReducer方案一

单独创建一个reducer/counter.js文件;

export default counterReducer(state,action){
	switch(){
		case "increment":
			return {...state,counter:state.counter+1}
		case "decrement":
			return {...state,counter:state.counter-1}
		default:
			return state;
	}
}

home.js

import React, { useReducer } from 'react'
import { counterReducer } from '../reducer/counter'

export default function Home() {
  const [state, dispatch] = useReducer(counterReducer, {counter: 100});

  return (
    <div>
      <h2>当前计数: {state.counter}</h2>
      <button onClick={e => dispatch({type: "increment"})}>+1</button>
      <button onClick={e => dispatch({type: "decrement"})}>-1</button>
    </div>
  )
}

我们来看一下,如果我们创建另一个profile.js也使用这个函数,是否进行数据的共享;

import React, { useReducer } from 'react'
import { counterReducer } from '../reducer/counter'

export default function Profile() {
  const [state, dispatch] = useReducer(counterReducer, {counter: 0});

  return (
    <div>
      <h2>当前计数: {state.counter}</h2>
      <button onClick={e => dispatch({type: "increment"})}>+1</button>
      <button onClick={e => dispatch({type: "decrement"})}>-1</button>
    </div>
  )
}

拆分useReducer方案二

单独创建一个useReducerText.jsx文件;

import React,{useReducer} from 'react'
function counterReducer (state,action){
  switch (action.type) {
    case "increment":
      return {...state,counter:state.counter+action.speed}
      case "decrement":
        return {...state,counter:state.counter-action.speed}
    default:
      return state;
  }
}

export default function useReducerText() {
  const [state,dispath]=useReducer(counterReducer,{counter:9})
  return [state,dispath]
}

home.jsx

import React from 'react'
import useReducerText from '../useReducerText.jsx'
export default function Home() {
  let [state,dispatch]=useReducerText()
  return (
    <div>
      <p>{state.counter}</p>
      <button onClick={()=>{
        dispatch({
          type:'increment',
          speed:2
        })
      }}>+</button>
      <button  onClick={()=>{
        dispatch({
          type:'decrement',
          speed:1
        })
      }}>-</button>
    </div>
  )
}

about.jsx

import React from 'react'
import useReducerText from '../useReducerText.jsx'
export default function About() {
  let [state,dispatch]=useReducerText()
  return (
    <div>
      <p>{state.counter}</p>
      <button onClick={()=>{
        dispatch({
          type:'increment',
          speed:4
        })
      }}>+</button>
      <button  onClick={()=>{
        dispatch({
          type:'decrement',
          speed:2
        })
      }}>-</button>
    </div>
  )
}

由拆分方案一和方案二可知,数据是不会共享的,它们只是使用了相同的counterReducer的函数而已;
所以,useReducer只是useState的一种替代品,并不能替代redux

上一篇:蓝桥杯VIP 基础练习 芯片测试 python解析


下一篇:操作系统--进程