react中的context怎么用(context,react,web开发)

时间:2024-05-03 07:06:32 作者 : 石家庄SEO 分类 : web开发
  • TAG :

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

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

react中context的用法是什么

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

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

基本使用方式

1、自定义Context

importReactfrom'react';constThemeContext=React.createContext('light');exportdefaultThemeContext;

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

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

importThemeContextfrom'./context/ThemeContext.js';importThemedButtonfrom'./ThemedButton.js';import'./App.css';functionApp(){return(<ThemeContext.Providervalue='dark'><divclassName="App"><headerclassName="App-header"><ThemedButton/></header></div></ThemeContext.Provider>);}exportdefaultApp;

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

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

importReact,{Component}from'react';importThemeContextfrom"./context/ThemeContext.js";classThemedButtonextendsComponent{staticcontextType=ThemeContext;render(){return<button>{this.context}</button>;}}exportdefaultThemedButton;

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

效果图:

react中的context怎么用

 </div> <div class="zixun-tj-product adv-bottom"></div> </div> </div> <div class="prve-next-news">
本文:react中的context怎么用的详细内容,希望对您有所帮助,信息来源于网络。
上一篇:elasticsearch怎么构造Client实现java客户端调用接口下一篇:

10 人围观 / 0 条评论 ↓快速评论↓

(必须)

(必须,保密)

阿狸1 阿狸2 阿狸3 阿狸4 阿狸5 阿狸6 阿狸7 阿狸8 阿狸9 阿狸10 阿狸11 阿狸12 阿狸13 阿狸14 阿狸15 阿狸16 阿狸17 阿狸18