javascript - Reactjs 使用数组动态调用选项卡面板下有卡片的组件

标签 javascript reactjs react-native jquery-ui-tabs

这是定义Tab header和tab content的地方,期望Tabs_content有组件名称,在tabpanel下应该遍历数组tabs_content并显示组件并调用图3所示的组件

let tabs_data= ['Add Queue','Edit Queue','Remove Queue'];
    let tabs_content= ['<AddQueueCard />','EditQueueCard','C content' ];
<div class="card-body">
        <div class="tab-content">
          <div class="tab-pane active">
          <div>
               <div  id="test">
        <Tabs>
          <ul>
            <TabList>
              
            {tabs_data.map(i => (
                <Tab>{i}</Tab>
                  ))}`***enter code here***`
            </TabList>
            </ul>
            {tabs_content.map(i => (
            
                <TabPanel>
              {i}   {/* here I want to call cards dynamically like <AddQueueCard /> <EditQueueCard> if clicked on 1st or 2nd tab respectively. How do I do that */}
               </TabPanel> 
            
              ))}
          </Tabs>
        </div>
        </div>
         </div>
          <div class="tab-pane">
      
          </div>
          
        </div>
      </div>

Currently cards are not called enter image description here Expected output

最佳答案

只需传递组件本身,但最好有一个单独的组件字典并循环渲染动态组件,不要将组件和其他东西混合在一个数组中,如果你这样做,你必须找到一种方法来检测它item是react组件,然后渲染它。

let tabs_data= ['Add Queue','Edit Queue','Remove Queue'];
let tabs_content= [AddQueueCard, EditQueueCard, 'C content'];

<div class="card-body">
  <div class="tab-content">
    <div class="tab-pane active">
      <div>
        <div id="test">
          <Tabs>
            <ul>
              <TabList>
                {tabs_data.map((i) => (
                  <Tab>{i}</Tab>
                ))}
              </TabList>
            </ul>
            {tabs_content.map((Item) => {
              return <TabPanel>
                {typeof Item === "function" ? <Item /> : Item}
              </TabPanel>
            })}
          </Tabs>
        </div>
      </div>
    </div>
    <div class="tab-pane"></div>
  </div>
</div>;

关于javascript - Reactjs 使用数组动态调用选项卡面板下有卡片的组件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/70312884/

相关文章:

ios - 找不到 -ljschelpers 的库

javascript - 如何使用矩阵从左上角缩放对象?

javascript - 过滤 jquery 输入中的名称

reactjs - Webpack 4 for SSR,如何解决此 ReferenceError : window is not defined?

reactjs - React Draft.js 工具栏插件未显示

reactjs - Jest 快照不适用于某些 Semantic-UI-React 组件

javascript - 带有 div 的表中的不对称行和列

javascript - 按索引对 javascript multliarray 进行分组并获得总和和平均值

javascript - TVMaze API 错误

javascript - React Native - 动画宽度收缩