繁体   English   中英

解析错误:必须将相邻的 JSX 元素包装在封闭标记中(React.js)

[英]Parse Error:Adjacent JSX elements must be wrapped in an enclosing tag(React.js )

我正在尝试设置我的 React.js 应用程序,以便它显示我的大菜单树。

我的渲染函数的设置方式如下:

    let menuTitle = ['受注数入力業務', '発注数入力業務', '各店発注数入力業務', '売仕搬入数入力業務', '実在庫数入力業務', '非定型伝票引渡し業務', '通常反品数入力業務', '雑搬入数入力業務', '発注数入力業務', '帳票出力/マスタ管理'];
    
    const menuSubTitele = new Map();

    menuSubTitele.set('受注数入力業務', ['01.受注数入力', '02.受注補正数入力', '03.チェックリスト確定', '04.受注データFD読込', '05.チェックリスト', '06.チェックリストⅡ', '07.受注データFD読込エラーリスト'])
    menuSubTitele.set('発注数入力業務', ['11.発注数入力', '12.発注数キャンセル', '13.チェックリスト', '14.チェックリストⅡ', '15.注文書出力'])
    menuSubTitele.set('各店発注数入力業務', ['51.各店発注数入力', '52.注文書出力', '53.チェックリスト'])
    menuSubTitele.set('売仕搬入数入力業務', ['21.売仕搬入数入力', '22.チェックリスト'])
    menuSubTitele.set('実在庫数入力業務', ['41.実在庫数入力', '42.チェックリスト'])
    menuSubTitele.set('非定型伝票引渡し業務', ['71.雑介入数入力', '72.非定型伝票引渡し明細出力'])
    menuSubTitele.set('通常反品数入力業務', ['31.返品数入力', '32.チェックリスト', '33.返品伝票出力', '34.チェックリストⅡ'])
    menuSubTitele.set('雑搬入数入力業務', ['81.雑搬入数入力', '82.チェックリスト'])
    menuSubTitele.set('発注数入力業務', ['61.返品数入力', '62.チェックリスト', '63.返品伝票出力', '64.チェックリストⅡ'])
    menuSubTitele.set('帳票出力/マスタ管理', ['90.帳票出力メニュー', '91.マスメ保守ニュー', '92.マスタ一覧メニュー', '93.マスタ管理メニュー'])

return ( 
       <div className='App'>
        <Drawer anchor={'left'} open={state['left']} onClose={toggleDrawer('left', false)}>      
        <List aria-label='secondary mailbox folders'  className = "leftMenu">
        {menuTitle.map((name) => (  
        <ListItem button onClick={handleClick}>{`${name}`}
         {open ? <ExpandLess /> : <ExpandMore />}
        </ListItem>
          <Collapse in={open} timeout="auto" unmountOnExit>
          <List component="div" disablePadding>
                {menuSubTitele[0].map((item) => (
                <ListItemLink to='' primary={`${item}`} /><Divider light />   
                ))}   
          </List>
          </Collapse>               
        ))}
        </List>   
        </Drawer>
   </div>);

但是在运行这个时,我得到了问题中的错误:

解析错误:相邻的 JSX 元素必须包含在封闭标记中。 你想要一个 JSX 片段 <>...</> 吗?

  |          {open ? <ExpandLess /> : <ExpandMore />}
  |         </ListItem>
> |           <Collapse in={open} timeout="auto" unmountOnExit>
  |           ^
  |           <List component="div" disablePadding>
  |                 {menuSubTitele[0].map((item) => (
  |                 <ListItemLink to='' primary={`${item}`} /><Divider light />   ```

I understood, that my map-function in HTML was breaking JSX Parsing , but have no any idea how fix it.

除非将它们包装在父元素中,否则不能映射多个元素。 为了澄清起见,您已经将<ListItemLink to='' primary={${item}} /><Divider light />映射<ListItemLink to='' primary={${item}} /><Divider light />而没有将它们包装在父元素中,这会导致错误。

尝试将映射元素包含在 div 或 React.Fragment 中

<List component="div" disablePadding>
  {menuSubTitele[0].map((item) => (
   <React.Fragment>
      <ListItemLink to='' primary={`${item}`} /><Divider light />
   </React.Fragment>)
  )}

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM