react中的context怎么用

这篇“react中的context怎么用”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“react中的context怎么用”文章吧。

创新互联是一家专业提供庆城企业网站建设,专注与网站设计制作、成都做网站H5网站设计、小程序制作等业务。10年已为庆城众多企业、政府机构等服务。创新互联专业网站设计公司优惠进行中。

在react中,context用于共享数据,并且允许数据隔代传递;context提供了一种新的组件之间共享数据的方式,不必显式地通过组件树的逐层传递props,能够避免使用大量重复的props来传递值。

本教程操作环境:Windows10系统、react17.0.1版、Dell G3电脑。

react中context的用法是什么

Context提供了一种新的组件之间共享数据的方式,允许数据隔代传递,而不必显式的通过组件树逐层传递props。

Context 提供了一种在组件之间共享值的方式,而不必显式地通过组件树的逐层传递 props。如果获取值和使用值的层级相隔很远,或者需要使用这个值的组件很多很分散,则可以使用Context来共享数据,避免使用大量重复的props来传递值。如果只是一个组件需要使用这个值,可以在产生这个值的位置生成这个组件,然后用props层层传递到组件实际展示的位置。

基本使用方式

1、自定义Context

import React from 'react';
 
const ThemeContext = React.createContext('light');
 
export default ThemeContext;

上面的代码定义了一个ThemeContext,默认值为'light'。

2、在需要的位置使用Context的Provider

import ThemeContext from './context/ThemeContext.js';
import ThemedButton from './ThemedButton.js';
import './App.css';
 
function App() {
  return (
    
      
        
          
        
      
       ); }   export default App;

在组件的最外层使用了自定义Context的Provider,传入value覆盖了默认值,之后子组件读到的ThemeContext的值就是'dark'而不是默认值'light'。如果Provider有value定义就会使用value的值(即使值是undefined,即未传入value),只有当Provider未提供时才会使用定义时的默认值。

3、定义contextType,使用获取到的Context上的值

import React, { Component } from 'react';
import ThemeContext from "./context/ThemeContext.js";
 
class ThemedButton extends Component {
static contextType = ThemeContext;
render() {
return ;
}
}
 
export default ThemedButton;

ThemedButton声明了contextType是ThemeContext,因此this.context的值就是最近的ThemeContext提供的value,也就是'light'。

效果图:

react中的context怎么用

以上就是关于“react中的context怎么用”这篇文章的内容,相信大家都有了一定的了解,希望小编分享的内容对大家有帮助,若想了解更多相关的知识内容,请关注创新互联行业资讯频道。


网站题目:react中的context怎么用
标题链接:http://bzwzjz.com/article/jescih.html

其他资讯

Copyright © 2007-2020 广东宝晨空调科技有限公司 All Rights Reserved 粤ICP备2022107769号
友情链接: 阿坝网站设计 成都品牌网站建设 成都网站设计 重庆企业网站建设 成都网站建设 成都企业网站建设 手机网站制作 成都企业网站制作 成都网站建设公司 成都网站设计制作公司 成都网站建设 企业网站设计 成都网站制作 成都网站建设 成都响应式网站建设 自适应网站设计 定制网站建设多少钱 成都网站设计 成都网站建设推广 高端品牌网站建设 手机网站建设 成都网站建设