React:动态导入jsx
这个问题与将JSX文件动态导入到React有关。
基本上,我们有一个主要组件,可以根据存储在数据库中的结构动态地呈现其他组件。动态组件存储在子目录“ ./Components”中。我们将此静态定义为:
import CompA from './Components/CompA';import CompB from './Components/CompB';
var components = {
'CompA': CompA,
'CompB': CompB
}
我们使用以下命令渲染它们:
var type = 'CompA' var Component = components[type];
...
<Component />
虽然这很好用,但对我们来说有点太静态了。我们有100多个组件(CompA / CompB),并且静态定义它们不起作用。
是否可以将所有JSX文件导入“ ./Compontents”并填充components-array?
而且,如果我们可以将“ ./Components”路径作为对主要组件的支持,那么真正(真正)不错。并且主要组件将使用此路径导入.jsx文件。像这样:
<MainComponent ComponentPath="./SystemComponents">
将使用“ ./SystemComponents”作为.JSX文件的路径,并且:
<MainComponent ComponentPath="./UserComponents">
将使用“ ./UserComponents”作为导入路径。
回答:
拥有一个具有内容的components / index.js怎么样:
export CompA from "./comp_a";export CompB from "./comp_b";
然后,您执行以下操作:
import * as Components from "./components"
那么您将使用:
<Components.CompA /><Components.CompB />
...
希望这可以帮助。
我怀疑您在通过组件prop发送路径时是否可以加载任何东西,然后应该在React组件生命周期方法内进行文件加载,这是我不推荐的。
以上是 React:动态导入jsx 的全部内容, 来源链接: utcz.com/qa/421980.html