无法动态地在react组件中创建元素

Sum*_*dey 9 reactjs

我无法动态创建React组件.我看到空白页面,下面的代码没有错误.

1)尝试创建名为"PieChart"的元素

2)下面是我在控制台中看到的两个错误.

1. Warning: <PieChart /> is using incorrect casing. Use PascalCase for    
   React components, or lowercase for HTML elements.

2. Warning: The tag <PieChart/> is unrecognized in this browser. If you
   meant to    render a React component, start its name with an
   uppercase letter.
Run Code Online (Sandbox Code Playgroud)

3)我已经在使用Pascal案例"PieChart"

import PieChart from "../component/PieChart";
class App extends Component {

  render() {
    const GraphWidget = React.createElement("PieChart");
    return (
      <div>
        {GraphWidget}

      </div>
    )
  }


}


export default App;
Run Code Online (Sandbox Code Playgroud)

Sul*_*han 12

createElement文档:

创建并返回给定类型的新React元素.type参数可以是标记名称字符串(例如"div"或"span"),React组件类型(类或函数)或React片段类型.

您正在尝试使用React组件类型,因此您不能使用字符串,您需要直接使用该类:

const GraphWidget = React.createElement(PieChart);
Run Code Online (Sandbox Code Playgroud)

如果您的目标是将字符串映射到组件,则可以使用字典创建简单映射:

const components = {
    PieChart: PieChart
    ...
};

const GraphWidget = React.createElement(components['PieChart']); 
Run Code Online (Sandbox Code Playgroud)