首页 > web前端 > js教程 > 如何在 React/JSX 中动态渲染组件?

如何在 React/JSX 中动态渲染组件?

Mary-Kate Olsen
发布: 2024-11-15 14:12:02
原创
508 人浏览过

How to Dynamically Render Components in React/JSX?

React/JSX 中的动态组件渲染

React 的 JSX 允许声明式组件渲染,但有时开发者可能需要基于他们的类型。

问题

尝试使用下面的代码片段动态渲染组件时,会发生错误:

var type = "Example";
var ComponentName = type + "Component";
return <ComponentName />; // Error: expected XML, got array
登录后复制

出现错误是因为代码使用数组语法,而 JSX 需要 XML 。其他解决方案,例如为每个组件创建一个方法,都不够优雅。

解决方案

React 文档现在提供了动态组件渲染的官方解决方案:

const MyComponent = Components[type + "Component"];
return <MyComponent />;
登录后复制

此代码编译为:

const MyComponent = Components[type + "Component"];
return React.createElement(MyComponent, {});
登录后复制

变量 MyComponent 存储组件类并且是大写的。然后 React.createElement 函数使用此类来创建组件元素。

以上是如何在 React/JSX 中动态渲染组件?的详细内容。更多信息请关注PHP中文网其他相关文章!

来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
作者最新文章
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板