react18使用useContext进行跨组件传参

contexts.js

import { createContext, useState } from "react";

const MyContext = createContext();

const MyContextProvider = ({ children }) => {
  const [value, setValue] = useState(0);
  const setNewValue = (newValue) => {
    setValue(newValue);
  };
  return (
    <MyContext.Provider value={{ value, setNewValue }}>
      {children}
    </MyContext.Provider>
  );
};

export { MyContext, MyContextProvider };

根组件

import React from "react";
import { MyContextProvider } from "./contexts";
import Son from "./pages/Son";

function App() {
  return (
    <div className="App">
      <MyContextProvider>
        <Son />
      </MyContextProvider>
    </div>
  );
}

export default App;

父组件

import React from "react";
import Sun from './Sun'

function Son() {
  return (
    <div>
      <Sun/>
    </div>
  );
}

export default Son;

子组件

import React,{useContext} from "react";
import {MyContext} from '../contexts'

function Sun() {
  const {value,setNewValue} = useContext(MyContext)
  return (
    <div>
       <button onClick={()=>{setNewValue(value + 1)}}>{value}</button>
    </div>
  );
}

export default Sun;

注:本人前端小白 ,如有不对的地方还请多多指教

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值