Kai*_*r69 5 javascript reactjs webpack
我有这个代码:
class Sidebar extends Component {
render() {
return (
<div className="sidebar">
{ this.props.children }
</div>
);
}
}
class Item extends Component {
render() {
return (
<div>
<b> { this.props.name } </b>
</div>
);
}
}
export { Sidebar, Item };
Run Code Online (Sandbox Code Playgroud)
export {default as Header} from './Header';
export {default as Footer} from './Footer';
export {default as Sidebar, Item} from './Sidebar';
Run Code Online (Sandbox Code Playgroud)
import { Sidebar } from '../components';
class App extends Component {
render() {
return (
<div>
<Header/>
<Sidebar>
<Sidebar.Item name='item1' />
<Sidebar.Item name='item2' />
<Sidebar.Item name='item3' />
</Sidebar>
<Footer/>
// ...
Run Code Online (Sandbox Code Playgroud)
我得到的错误是:
TypeError:无法读取未定义的属性"Item"
如何在多个导出组件中index.js
调用另一个文件?我确信页眉和页脚正常工作,因为我在该文件中只有一个类.
function Sidebar(props) {
return (
<div className="sidebar">
{ props.children }
</div>
);
}
function Item (props) {
return (
<div>
<b> { this.props.name } </b>
</div>
);
}
Sidebar.Item = {Item}
export default Sidebar
Run Code Online (Sandbox Code Playgroud)
然后你可以像这样使用它
import Sidebar from './Sidebar.js'
...
return (
<Sidebar>
<Sidebar.Item />
</Sidebar>
)
Run Code Online (Sandbox Code Playgroud)
如果您使用的是基于类的组件,则可以删除花括号
class Sidebar extends Component {
render() {
return (
<div className="sidebar">
{this.props.children}
</div>
);
}
}
class SidebarItem extends Component {
render() {
return (
<div>
<b> {props.name} </b>
</div>
);
}
Sidebar.Item = SidebarItem;
export default Sidebar;
Run Code Online (Sandbox Code Playgroud)
我从同事那里学到了这种做法,在同一个语义ui表中看到了这种做法.