React context - 'contextType' 未定义

2024-01-06

我在用[电子邮件受保护] /cdn-cgi/l/email-protection and [电子邮件受保护] /cdn-cgi/l/email-protection应该支持反应Context并尝试运行一个与以下相同的简单示例反应上下文 https://reactjs.org/docs/context.html:

app.js

import React, { Component } from 'react';
import AppManger from './components/AppManger';
import './App.css';
export const ThemeContext = React.createContext({a1:'a1'});

class App extends Component {

  render() {

    return (

      <div className="App">
        <h1>Manage Storefront Services Products</h1>
        <ThemeContext.Provider value="dark">
          <AppManger />
        </ThemeContext.Provider>

      </div>

    );
  }
}

export default App;

AppManger.js(没有上下文引用)

import React, { Component } from 'react'
import SearchBar from './SearchBar';
export default class AppManger extends Component {


    constructor(props) {
        super(props);
        this.onSearchBarChange = this.onSearchBarChange.bind(this);
        this.state = {
            searchValue: '',
            errorLoading: false,
            errorObj: null,
        }
    }

    onSearchBarChange(e) {
        e.persist();
        this.setState({ searchValue: e.target.value });
    }

    render() {
        return (

            <div>
                <a href="/subsadmin/saml/logout">Log out</a>
                <SearchBar onSearchBarChange={this.onSearchBarChange} inAttrView={this.state.onAttrPage} />
            </div>

        )
    }
}

以及我想使用 Context 的 SearchBar.js:

import React, { Component } from 'react';
import ThemeContext from '../App';


export default class SearchBar extends Component {
  constructor(props) {
    super(props);
    this.state = {
      showModal: false,
      showAttrModal: false
    };

  };


  componentDidMount(){
    console.log(this.context); //{}
  }

  render() {
    const contextType = ThemeContext;
    console.log(contextType); //{}
    return (

      <div>
        {contextType} /*'contextType' is not defined  no-undef */
        <input type="text" style={searchBoxStyle} className="form-control" onChange={this.props.onSearchBarChange} placeholder="Search for..." id="sku" name="sku" />

      </div>

    )
  }
}

如果我运行该应用程序,我会得到Line 44: 'contextType' is not defined no-undef在 SearchBar.js 中,如果我删除这一行,我会得到{}当我记录时this.context.


您没有正确使用上下文,因为您需要将其定义为类的静态属性并将其作为命名导入导入,因为您已将其导出为命名导入

import { ThemeContext } from '../App';

export default class SearchBar extends Component {
  constructor(props) {
    super(props);
    this.state = {
      showModal: false,
      showAttrModal: false
    };

  };

  static contextType = ThemeContext;
  componentDidMount(){
    console.log(this.context); //{}
  }

  render() {

    console.log(this.contextType); //{}
    return (

      <div>
        {contextType} /*'contextType' is not defined  no-undef */
        <input type="text" style={searchBoxStyle} className="form-control" onChange={this.props.onSearchBarChange} placeholder="Search for..." id="sku" name="sku" />

      </div>

    )
  }
}
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

React context - 'contextType' 未定义 的相关文章

随机推荐

  • 如何使用 ES6 模块导入 jQuery Masonry?

    我正在尝试使用这个 npm 包https www npmjs com package masonry layout https www npmjs com package masonry layout 根据我运行的安装说明 npm inst
  • 为什么 Unicode 限制为 0x10FFFF?

    为什么最大 Unicode 代码点限制为 0x10FFFF 是否可以在该代码点之上表示 Unicode 例如0x10FFFF 0x000001 0x110000 通过任何编码方案 如 UTF 16 UTF 8 It s because of
  • 内联 CSS 图像和段落内联

    我无法让我的 div 在同一行上布局图像和段落 我在堆栈溢出和谷歌上搜索了许多主题 但没有解决方案有效 由于网络主机的原因 我必须使用内联 css 来设置网站的样式 相信我 我更愿意使用 css 文件 但由于所选的网络主机而无法这样做 通常
  • 替换换行符以使它们与 jquery 一起使用

    我有以下小脚本来预览一些文本 然后再将其提交到数据库中 jQuery function var input contents preview previewaccordion div viewcontents input keyup fun
  • 在类路径上发现多次出现 org.json.JSONObject:[重复]

    这个问题在这里已经有答案了 我有一个基本的 Spring Boot 2 1 5 RELEASE 应用程序 使用 Spring Initializr JPA 嵌入式 Tomcat Thymeleaf 模板引擎 并打包为可执行 JAR 当我启动
  • 如何以编程方式在反应本机中截取屏幕截图

    如何在 React Native 中截取屏幕截图 我需要截图并将其放入Image成分 我该怎么办 有一个库可以做到这一点 反应本机视图镜头 https github com gre react native view shot import
  • 如何在 Angular 4 材料排序中对日期/时间列进行排序?

    我正在使用角度材料表并使用 matSort 进行排序 但它没有对日期 时间列进行排序 它将日期时间列值作为字符串 如何对 Angular 4 材料中的日期 时间列进行排序 我的 json 看起来像这样 name Rule Test 5 ti
  • 如何调试配置 django 以使用 apache 和 mod-wsgi 提供服务的基本问题?

    人们在设置 django 以由 apache 和 mod wsgi 提供服务时遇到困难是很常见的 常见的症状是 导入错误 由于某种原因 通常在每种情况下略有不同 settings py 或类似的文件无法导入 有关众多示例 请参阅本页右栏中的
  • C 编程语言,第 1 章练习 1.10(Getchar 和 Putchar)

    我已经为此工作了 2 个小时 但我被困住了 我在网上找到了答案 但这并不能帮助我学习我显然缺少的概念 Prompt 编写一个程序将其输入复制到输出 将每个选项卡替换为 t 每个退格键 b 以及每个反斜杠 这使得制表符和退格键以明确的方式可见
  • Python 中断言的使用示例?

    我已经读过有关何时使用断言与异常的信息 但我仍然没有 明白 似乎每当我认为我处于应该使用断言的情况时 在后来的开发中我发现我 三思而后行 以确保当我调用函数时断言不会失败 由于还有另一个 Python 习惯用法 即更喜欢使用 try exc
  • 在运行时创建TabView?

    我需要使用 java 代码在运行时创建选项卡视图 笔记 不使用xml设计 在 XML 中创建 TabHost TabWidget 然后在运行时添加 TAbHost TabSpec
  • 如何创建 C 头文件 [关闭]

    Closed 这个问题需要多问focused help closed questions 目前不接受答案 我希望能够在头文件中创建一组函数 我可以将其 include 到我的一个 C 程序中 打开您最喜欢的文本编辑器 创建一个名为whate
  • 带有 Spring 缓存和咖啡因的 Spring 云网关

    我有一个 Spring Cloud 网关 它将 API 剩余请求转发到一些微服务 我想缓存特定请求的响应 为此我写了这个过滤器 Component Slf4j public class CacheResponseGatewayFilterF
  • 在 chrome 扩展中正确使用 execcommand("paste")

    我正在尝试使用以下命令将剪贴板数据粘贴到文本区域中execcommand paste 带有 chrome 扩展 但我似乎无法让它工作 权限已设置 我尝试过设置focus 在文本区域上 但是document execCommand paste
  • numpy 数组之间的“in”运算符的含义是什么?

    我注意到in可以在 numpy 数组之间使用 然而 它的含义可能有点违反直觉 import numpy as np np array 0 in np array 1 2 False np array 0 in np array 0 1 Tr
  • 如何使用 iDangerous Swiper 和 jquery .click();同时

    我坚持以下几点 我正在使用 iDangerous Swiper 插件 效果很好 但是 我还想在同一个 iDangerous swiper 上使用 jQuery 的单击功能 例如 div div class swiper slide lots
  • 如何使用 LINQ 查找并删除集合中的重复对象?

    我有一个代表对象的简单类 它有 5 个属性 一个日期 两个小数 一个整数和一个字符串 我有一个集合类 源自CollectionBase 这是一个容器类 用于保存我的第一个类中的多个对象 我的问题是 我想删除重复的对象 例如具有相同日期 相同
  • 如何对 IBM Cloud 数据库进行按需备份

    我在 IBM Cloud 中有一个 Elasticsearch 部署 我想从中定期进行按需备份 有没有办法使用命令行启动备份 IBM Cloud 数据库每天定期备份其所有数据库 但您无法选择备份计划 如果您想更频繁地创建备份或继续创建备份
  • 我应该对 Asp.NET Web-api 路由使用 RouteParameter 还是 UrlParameter?

    我见过两者都被使用 所以我想知道 它们做相同的事情还是不同的事情 如果是后者 有什么区别呢 我尝试通过查看 Visual Studio MVC 4 rc Web api 模板来自己回答这个问题 但遗憾的是它同时使用了两者 所以我的困惑仍然存
  • React context - 'contextType' 未定义

    我在用 电子邮件受保护 cdn cgi l email protection and 电子邮件受保护 cdn cgi l email protection应该支持反应Context并尝试运行一个与以下相同的简单示例反应上下文 https r