我的编程空间,编程开发者的网络收藏夹
学习永远不晚

react中的context怎么用

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

react中的context怎么用

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

在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 (
    <ThemeContext.Provider value='dark'>
      <div className="App">
        <header className="App-header">
          <ThemedButton />
        </header>
      </div>
    </ThemeContext.Provider>
  );
}
 
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 <button>{this.context}</button>;
}
}
 
export default ThemedButton;

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

效果图:

react中的context怎么用

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

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

react中的context怎么用

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

Context怎么在React中应用

本篇文章给大家分享的是有关Context怎么在React中应用,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。Context定义和目的Context 提供了一种在组件之间共享数据
2023-06-15

怎么封装React Context Composer

本篇内容主要讲解“怎么封装React Context Composer”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“怎么封装React Context Composer”吧!我是如何一步步封装一
2023-06-22

React Context的用法分析

这篇文章将为大家详细讲解有关React Context的用法分析,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。前言Context被翻译为上下文,在编程领域,这是一个经常会接触到的概念,React中也有。在
2023-06-14

Go中的Context怎么使用

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

JS中的:host ,:host-context和::ng-deep怎么用

这篇文章主要介绍“JS中的:host ,:host-context和::ng-deep怎么用”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“JS中的:host ,:host-context和::ng-
2023-06-27

Web应用中怎么设置Context Path

要设置Web应用的Context Path,可以在Web应用的部署描述文件中指定。在Java EE中,可以在web.xml文件中使用元素来设置Context Path。示例代码如下:c
Web应用中怎么设置Context Path
2024-03-05

Golang中的context包有什么用

Context 包是 Go 语言中用来传递请求范围变量、取消信号以及超时时间的包。它主要用于在 Goroutine 之间传递请求作用域的信息,比如传递请求的上下文、超时、取消信号等。通过 Context 包,可以有效控制 Goroutine
Golang中的context包有什么用
2024-03-13

React报错useNavigate() may be used only in context of Router怎么解决

今天小编给大家分享一下React报错useNavigate() may be used only in context of Router怎么解决的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参
2023-07-04

react中的useMemo怎么使用

今天小编给大家分享一下react中的useMemo怎么使用的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。概念react 中是
2023-07-04

编程热搜

目录