Search
 
SCRIPT & CODE EXAMPLE
 

JAVASCRIPT

usereducer hook react

import React, { useReducer } from 'react'
import { render } from 'react-dom'

const types = {
  PET: 'PET',
  COLOR: 'COLOR',
}

const reducer = (state, action) => {
  switch (action.type) {
    case types.PET:
      return { ...state, pet: action.value }
    case types.COLOR:
      return { ...state, color: action.value }
  }
}

const initialState = {
  color: 'black',
  pet: 'cat',
}

export default function App() {
  const [state, dispatch] = useReducer(reducer, initialState)

  return (
    <div>
      <label>Choose a color and a pet: </label>
      <br />
      <select
        value={state.color}
        onChange={event => {
          dispatch({ type: types.COLOR, value: event.target.value })
        }}
      >
        <option value="black">Black</option>
        <option value="pink">Pink</option>
        <option value="blue">Blue</option>
      </select>
      <select
        value={state.pet}
        onChange={event => {
          dispatch({ type: types.PET, value: event.target.value })
        }}
      >
        <option value="cat">Cat</option>
        <option value="dog">Dog</option>
        <option value="mouse">Mouse</option>
      </select>
      <br />
      <br />
      You chose a {state.color} {state.pet}
    </div>
  )
}

render(<App />, document.querySelector('#app'))
Comment

useReducer Hooks

const [state, dispatch] = useReducer(reducer, initialArg, init);

const initialState = {count: 0};

function reducer(state, action) {
  
  switch (action.type) {
    case 'increment':
      return {count: state.count + 1};
    case 'decrement':
      return {count: state.count - 1};
    default:
      throw new Error();
  }
}

function Counter() {
  const [state, dispatch] = useReducer(reducer, initialState);
  return (
    <>
      Count: {state.count}
      <button onClick={() => dispatch({type: 'decrement'})}>-</button>
      <button onClick={() => dispatch({type: 'increment'})}>+</button>
    </>
  );
}
const [state, dispatch] = useReducer(
    reducer,
    {count: initialCount}
  );
Comment

React useReducer Hook

import { useReducer } from "react";
import ReactDOM from "react-dom/client";

const initialTodos = [
  {
    id: 1,
    title: "Todo 1",
    complete: false,
  },
  {
    id: 2,
    title: "Todo 2",
    complete: false,
  },
];

const reducer = (state, action) => {
  switch (action.type) {
    case "COMPLETE":
      return state.map((todo) => {
        if (todo.id === action.id) {
          return { ...todo, complete: !todo.complete };
        } else {
          return todo;
        }
      });
    default:
      return state;
  }
};

function Todos() {
  const [todos, dispatch] = useReducer(reducer, initialTodos);

  const handleComplete = (todo) => {
    dispatch({ type: "COMPLETE", id: todo.id });
  };

  return (
    <>
      {todos.map((todo) => (
        <div key={todo.id}>
          <label>
            <input
              type="checkbox"
              checked={todo.complete}
              onChange={() => handleComplete(todo)}
            />
            {todo.title}
          </label>
        </div>
      ))}
    </>
  );
}

const root = ReactDOM.createRoot(document.getElementById('root'));
root.render(<Todos />);
Comment

useReducer() hook react

code snippet 

https://codesandbox.io/s/usereducer-demo-zxguu?file=/src/App.js
Comment

usestate or usereducer

//When it's just an independent element of state you're managing

useState
Comment

PREVIOUS NEXT
Code Example
Javascript :: basics of switch case and if else 
Javascript :: js to find value in array 
Javascript :: angular material moduel 
Javascript :: call a javascript function at a specific time of day 
Javascript :: solcjs 
Javascript :: Merging Or Copying Arrays Using Spread Operator 
Javascript :: regex forms 
Javascript :: jquery properly work 
Javascript :: .reduce mdn 
Javascript :: npm: Create react chrome extension 
Javascript :: prisma.db sqlite 
Javascript :: connectedcallback web components 
Javascript :: javascript custom modal 
Javascript :: unknown provider angularjs 
Javascript :: code to convert rgb to hsl color 
Javascript :: jsonplaceholder typicode 
Javascript :: d-block d-none js 
Javascript :: stripe delete product 
Javascript :: add two empty arrays javascript 
Javascript :: array from javascript 
Javascript :: angular reference element 
Javascript :: nextjs starter 
Javascript :: chatbot using html and javascript 
Javascript :: padend javascript 
Javascript :: aws lambda send json 
Javascript :: javascript switch items in array 
Javascript :: declaring two variables inside for loop 
Javascript :: prevent history back javascript 
Javascript :: add webpack to react project 
Javascript :: angular how to use service in class 
ADD CONTENT
Topic
Content
Source link
Name
5+2 =