ES6 array map doesn't return anything: ReactJS

后端 未结 2 623
慢半拍i
慢半拍i 2020-11-27 22:25

I have an array and i have a simple string value. I want to mapping my array because i\'m try to find my string value.

I have a code like this, but map function doe

相关标签:
2条回答
  • 2020-11-27 23:11

    Because you are not returning anything from renderKeywords method, you are returning from map body only. If you don't return anything from function then by default it will return undefined, you need to return the result of map (array of elements).

    Like this:

    renderKeywords() {
        return this.state.question.map((item, key) => {   //here
            return (
                <span key={key}> {item} </span>
            );
        }); 
    }
    

    In short you can write it like this:

    renderKeywords() {
       return this.state.question.map((item, key) => <span key={key}> {item} </span> ); 
    }
    

    Suggestion:

    Assign unique key to each element.

    Check this answer for more details about key: Understanding unique keys for array children in React.js

    0 讨论(0)
  • 2020-11-27 23:17

    you should return the map function itself, and you can achieve it with es6 single line arrow functions too

    class Application extends React.Component {
      constructor(){
        super();
    
        this.state = {
          questionAnswer: 'is that possible',
          question: ['is', 'possible', 'that']
        }  
      }
    
      renderKeywords() {
        return this.state.question.map((item, i) =><span key={i}>{item}
       </span>}); 
      }
    
      render() {
        return (
          <div>
            <div>blabla</div>
            {this.renderKeywords()}  
          </div>
       );
     }
    }
    React.render(<Application />, document.getElementById('app'));
    
    0 讨论(0)
提交回复
热议问题