使用Context Hook

基础context写法

import React,{createContext, useState} from 'react';

const CountContext = createContext();

class Foo extends React.Component{

  render(){
    return (
      <CountContext.Consumer>
        {
          count => <h1>{count}</h1>
        }
      </CountContext.Consumer>
    );
  }
}

export default function App() {
  const [count,setCount] = useState(0);
  return (
    <div>
      <button
        type="button"
        onClick={()=>{setCount(count+1)}}
      >
      Click({count})
      </button>
      <CountContext.Provider value={count}>
        <Foo/>
      </CountContext.Provider>

    </div>
    
      
  );
  
}

contextType写法

import React,{createContext, useState} from 'react';

const CountContext = createContext();

class Foo extends React.Component{
  static contextType = CountContext; 
  render(){
    const count = this.context;
    return (
      <h1>{count}</h1>
    );
  }
}

export default function App() {
  const [count,setCount] = useState(0);
  return (
    <div>
      <button
        type="button"
        onClick={()=>{setCount(count+1)}}
      >
      Click({count})
      </button>
      <CountContext.Provider value={count}>
        <Foo/>
      </CountContext.Provider>

    </div>
    
      
  );
  
}

hook组件方式的context

import React,{createContext, useState,useContext} from 'react';

const CountContext = createContext();

function Foo(){
  const count = useContext(CountContext);
  return (
    <h1>{count}</h1>
  );
}

export default function App() {
  const [count,setCount] = useState(0);
  return (
    <div>
      <button
        type="button"
        onClick={()=>{setCount(count+1)}}
      >
      Click({count})
      </button>
      <CountContext.Provider value={count}>
        <Foo/>
      </CountContext.Provider>

    </div>
    
      
  );
  
}

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值