码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • React报错之Functions are not valid as a React child


    正文从这开始~

    总览

    产生"Functions are not valid as a React child. This may happen if you return a Component instead of  from render."错误,通常是因为以下两个原因:

    1. 从render中返回一个函数引用而不是一个组件。
    2. 使用 react router 路由作为 ,而不是} /> 。

    functions-are-not-valid-as-react-child.png

    这里有个例子来展示错误是如何发生的。

    // App.js
    /**
     * ⛔️ Functions are not valid as a React child.
     * This may happen if you return a Component instead of  from render.
     *  Or maybe you meant to call this function rather than return it.
     */
    const App = () => {
      const getButton = () => {
        return <button>Clickbutton>;
      };
    
      // 👇️ returning function not JSX element from render
      return <div>{getButton}div>;
    };
    
    export default App;
    

    上面代码片段的问题在于,我们从render方法中返回getButton函数,而不是返回真正的JSX元素。

    调用函数

    为了解决这种情况下的错误,我们可以调用该函数。

    const App = () => {
      const getButton = () => {
        return <button>Clickbutton>;
      };
    
      // ✅ now returning the actual button
      // added parenthesis () to call the function
      return <div>{getButton()}div>;
    };
    
    export default App;
    

    通过调用getButton函数,我们返回了button元素从而解决了该错误。

    如果你正在尝试渲染一个真正的组件,确保将其用作而不是Component。

    const App = () => {
      const Button = () => {
        return <button>Clickbutton>;
      };
    
      // ✅ Using component as 

    另一个导致该错误的原因是,当我们为react router 路由传递一个元素时,比如 。

    // ⛔️ wrong syntax
    <Route path="/about" element={About} />
    
    // ✅ right syntax
    <Route path="/about" element={<About />} />
    

    在 react router v6 中,我们不向 Route 组件传递 children 属性,而是使用 element 属性。例如,} />。

    当使用react router时,请确保将应该为特定路由渲染的组件作为,而不是Component。

    总结

    可以通过以下两种方式解决错误:

    1. 从render中返回组件而不是函数。
    2. 传递给路由中element属性的是,而不是Component。
  • 相关阅读:
    R语言读取(加载)txt格式数据为dataframe、为dataframe中的两个离散变量构建列联表
    JavaScript面向对象
    数据结构与算法(C语言版)P8---树、二叉树、森林
    一晚上做了一个xpath终结者:xpath-helper-plus
    决策树(二):后剪枝,连续值处理,数据加载器:DataLoader和模型评估
    玄子Share - IDEA 2023.1 自定义 代码模板(Servlet)
    Webpack Bundle Analyzer包分析器
    报错The chromedriver version cannot be discovered以及下载chromedriver.exe和查看其版本的命令
    机器人轨迹规划中经常用到的曲线特性小结:Cn连续与Gn连续、Frenet标架、曲率和挠率
    python安装及环境配置相关问题记录
  • 原文地址:https://www.cnblogs.com/chuckQu/p/16584293.html
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号