gpt4 book ai didi

javascript - React - 动态导入组件

转载 作者:可可西里 更新时间:2023-11-01 02:04:52 24 4
gpt4 key购买 nike

我有一个页面,它根据用户输入呈现不同的组件。目前,我已经对每个组件的导入进行了硬编码,如下所示:

    import React, { Component } from 'react'
import Component1 from './Component1'
import Component2 from './Component2'
import Component3 from './Component3'

class Main extends Component {
render() {
var components = {
'Component1': Component1,
'Component2': Component2,
'Component3': Component3
};
var type = 'Component1'; // just an example
var MyComponent = Components[type];
return <MyComponent />
}
}

export default Main

但是,我一直在更改/添加组件。有没有办法让一个文件只存储组件的名称和路径,然后将这些动态导入另一个文件?

最佳答案

我认为对于我试图实现的目标可能存在一些混淆。我设法解决了我遇到的问题,并在下面展示了我的代码,展示了我是如何解决它的。

单独的文件(ComponentIndex.js):

    let Components = {};

Components['Component1'] = require('./Component1').default;
Components['Component2'] = require('./Component2').default;
Components['Component3'] = require('./Component3').default;

export default Components

主文件(Main.js):

    import React, { Component } from 'react';
import Components from './ComponentIndex';

class Main extends Component {
render () {
var type = 'Component1'; // example variable - will change from user input
const ComponentToRender = Components[type];
return <ComponentToRender/>
}
}

export default Main

这种方法允许我非常快速地添加/删除组件,因为导入在一个文件中并且一次只需要更改一行。

关于javascript - React - 动态导入组件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/48268507/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com