array.map在reactjs中不起作用

时间:2017-01-19 06:19:06

标签: javascript arrays reactjs mapping

我的数组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

2 个答案:

答案 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>
        )}
}