gpt4 book ai didi

javascript - 函数作为 React 子项无效。 - React 中的功能组件

转载 作者:行者123 更新时间:2023-12-02 21:07:39 25 4
gpt4 key购买 nike

我目前正在尝试将 Patternfly React 集成到我的项目中。 This是我用作引用的链接,工作正常。但需要有单独的 header 、 footer 、 topnav 和 sidenav 组件。因此,在将代码划分为组件时,我遇到的问题是

Invalid prop nav supplied to PageSidebar, expected a ReactNode.

这是我的 Sidenav 代码

import ReactDOM from 'react-dom';
import "@patternfly/react-core/dist/styles/base.css";
import '../../app/fonts.css';

import React from 'react';
import {
Nav,
NavExpandable,
NavItem,
NavList
} from '@patternfly/react-core';

function SideNav() {

this.state = {
activeGroup: 'grp-1',
activeItem: 'grp-1_itm-1'
};

this.onNavSelect = result => {
this.setState({
activeItem: result.itemId,
activeGroup: result.groupId
});
};

const { activeItem, activeGroup } = this.state;

const PageNav = (
<Nav onSelect={this.onNavSelect} aria-label="Nav" theme="dark">
<NavList>
<NavExpandable title="System Panel" groupId="grp-1" isActive={activeGroup === 'grp-1'} isExpanded>
<NavItem groupId="grp-1" itemId="grp-1_itm-1" isActive={activeItem === 'grp-1_itm-1'}>
Overview
</NavItem>
<NavItem groupId="grp-1" itemId="grp-1_itm-2" isActive={activeItem === 'grp-1_itm-2'}>
Resource usage
</NavItem>
<NavItem groupId="grp-1" itemId="grp-1_itm-3" isActive={activeItem === 'grp-1_itm-3'}>
Hypervisors
</NavItem>

</NavExpandable>
</NavList>
</Nav>
);


return (PageNav);


}

export default SideNav;

上面是我的 sideNav 功能组件,并在我的布局组件中使用它。

我的标题组件

import "@patternfly/react-core/dist/styles/base.css";
import '../../app/fonts.css';

import React from 'react';
import {
Page,
PageHeader,
PageSection,
PageSectionVariants,
PageSidebar,
TextContent,
Text,
} from '@patternfly/react-core';

import SideNav from '../sideNav/sideNav';

class Layout extends React.Component {

render() {

const Header = (
<PageHeader
toolbar={PageToolbar}
showNavToggle
/>
);
const Sidebar = <PageSidebar nav={SideNav} theme="dark" />;


return (
<React.Fragment>
<Page
header={Header}
sidebar={Sidebar}
mainContainerId={pageId}
>
<PageSection variant={PageSectionVariants.light}>
<TextContent>
<Text component="h1">Main title</Text>
<Text component="p">
Body
</Text>
</TextContent>
</PageSection>

</Page>
</React.Fragment>
);
}
}

export default Layout;

问题是当我将函数组件传递到 nav 属性中的 Patternfly 的 PageSidebar 组件时 const Sidebar = <PageSidebar nav={SideNav} theme="dark" />; .

这到底是哪里出了问题?

最佳答案

查看 seed app 中的代码,nav <PageSidebar>的属性(property)设置为某些 React 元素(某些 JSX),而不是 React 组件(返回某些 JSX 的函数)。

我想而不是使用 nav={Sidenav} ,你应该使用nav={<Sidenav />} ,使您的代码与示例匹配。

关于javascript - 函数作为 React 子项无效。 - React 中的功能组件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/61183476/

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