我的数组tabList
未映射到我需要的<li>
标记。
我做错了什么。
import React, { Component } from 'react'
// import NeilProfile from './neil-profile.jpg'
import Expertise from './expertise'
import Work from './work'
import Activity from './activity'
export class Bottom extends Component {
constructor (props) {
super(props)
this.state = { currentTab: 1 }
this.changeTab = this.changeTab.bind(this)
}
changeTab (id) {
this.setState({ currentTab: id })
}
render () {
const tabList = [
{ 'id': 1, 'name': 'Work' },
{ 'id': 2, 'name': 'Expertise' },
{ 'id': 3, 'name': 'Activity'}
]
return (
<div className='profile-bottom'>
<header>
<ul className='profile-bottom__tab-navigation'>
{tabList.map(function(tab) {
<li key={tab.id} className={(this.state.currentTab === tab.id) ? 'active' : null}>
<a onClick={() => this.changeTab(tab.id)} >
{tab.name}
</a>
</li>
}.bind(this))}
</ul>
<div className='profile-bottom__filter'>
<p>Show only: <span>Articles</span></p>
</div>
</header>
<div className='profile-bottom__content'>
{this.state.currentTab === 1 ?
<Work />
:null}
{this.state.currentTab === 2 ?
<Expertise />
:null}
{this.state.currentTab === 3 ?
<Activity />
:null}
</div>
</div>
)
}
}
export default Bottom
答案 0 :(得分:1)
您在地图功能中缺少返回。像这样更新您的地图功能 -
return (<li key={tab.id} className={(this.state.currentTab === tab.id) ? 'active' : null}>
<a onClick={() => this.changeTab(tab.id)} >
{tab.name}
</a>
</li>)
答案 1 :(得分:0)
尝试任何一个:
{
tabList.map(tab =>
<li key={tab.id} className={(this.state.currentTab === tab.id) ? 'active' : null}>
<a onClick={() => this.changeTab(tab.id)} >
{tab.name}
</a>
</li>
}
或
{
tabList.map(tab => {
return (
<li key={tab.id} className={(this.state.currentTab === tab.id) ? 'active' : null}>
<a onClick={() => this.changeTab(tab.id)} >
{tab.name}
</a>
</li>
)}
}