'React dynamic page render by api response

I have an api that returns JSON with object array {component_name: string, component_data: any}. Based on this response render react page using function with switch-case by component_name and pass data to component in this case. I have many componets and this switch is very large. Can it be solved differently?

code snippet eg.

import Header from "./Header";
import Link from "./Link";
import Image from "./Image";

const pageComponents = (pageJson) => pageJson.map(p => {
  switch(p.component_name) {
     case: 'header': {
       return <Header content={p.component_data.text} />

     case: 'link': {
       return <Link content={p.component_data.text} href={p.component_data.src} />

     case: 'image': {
       return <Image src={p.component_data.src} alt={p.component_data.alt} />

     }
   }
});



const EgPage = () => {

const pageJSON = [
 {component_name: 'header', component_data: {text: 'Heder text 1'}},
 {component_name: 'link', component_data: {text: 'Heder text 2', src: 'www.test.com'}},
 {component_name: 'image', component_data: {src: 'www.test.img/1.jpg', alt: 'Test img'},
 {component_name: 'header', component_data: {text: 'Heder text 2'},
]

return <div>{pageComponents(pageJSON)}</div>
}




Sources

This article follows the attribution requirements of Stack Overflow and is licensed under CC BY-SA 3.0.

Source: Stack Overflow

Solution Source