如何修复'TypeError:无法在React中读取未定义的属性'map'

时间:2019-01-12 12:36:23

标签: reactjs map-function

你好,我是React的新手,试图显示状态下创建的名为Todo的数组,但是出现错误“ TypeError:无法读取未定义的属性'map'”。你能告诉我我做错了什么吗?

这是我的代码

index.js

import React from 'react';
import ReactDOM from 'react-dom';

import App from './App';
import * as serviceWorker from './serviceWorker';

ReactDOM.render(<App />, document.getElementById('root'));

serviceWorker.unregister();

App.js

import React, { Component } from 'react';
import Todos from './component/Todos.js';
import './App.css'

class App extends Component {
  state={
    todos:[
        {
            id: 1,
            title:'Star Wars',
            point:9,
            watched: true
        },
        {
            id: 2,
            title:'Into the Wild',
            point:null,
            watched: false
        },
        {
            id: 3,
            title:'Enter the Void',
            point:6,
            watched: true
        },
        {
            id: 4,
            title:'Tschick',
            point:7.5,
            watched: true
        }
    ]
  }
  render() {
    return (
      <div className="App">
       <Todos />
      </div>
    );
  }
}

export default App;

Todo.js

import React, { Component } from 'react';


class Todos extends Component {

  render() {

    return this.props.todos.map((todo) => (
        <div>
        <h3>{todo.title}</h3>
        </div>
    ));
  }
}


export default Todos;

The error that I get

2 个答案:

答案 0 :(得分:3)

您没有将todos变量传递给组件。

您必须像这样传递属性:

<Todos todos={this.state.todos} />

答案 1 :(得分:0)

在您的App.js中,从州呼叫待办事项

<Todos todos={this.state.todos}/>

那之后应该可以正常工作