我正在编写一个程序,其中通过状态将数组中的项目列表从App组件传递到QuizApp组件,再从该组件传递到Turn组件。我想问题是Turn组件无法读取从AuthorsQuiz组件传递的道具。
我试图将状态对象转换为数组,但仍然发出相同的错误:
TypeError: Cannot read property 'imageUrl' of undefined
App.js
import React, { Component } from 'react';
import AuthorsQuiz from './Components/AuthorsQuiz';
import './App.css';
import {shuffle,sample} from 'underscore';
const authors =[
{
name: 'Mark Twain',
imageUrl:'',
imageSource:'Wikimedia Commons',
books: ['The Adventures of Huckleberry Finn']
},
{
name: 'Joseph Conrad',
imageUrl:'',
imageSource:'Wikimedia Commons',
books: ['Heart of darkness']
},
{
name: 'J K Rowling',
imageUrl:'',
imageSource:'Wikimedia Commons',
imageAttribution:'Daniel Ogren',
books: ['Harry Porter and sorcerers stone']
},
{
name: 'Stephen King',
imageUrl:'https://vignette.wikia.nocookie.net/stephenking/images/a/a0/Stephen_king-coming-to-boulder.jpg/revision/latest/scale-to-width-down/275?cb=20170530002714',
imageSource:'Wikimedia Commons',
imageAttribution:'Pingiun',
books: ['The shining', 'IT']
},
{
name: 'Charlse Dickens',
imageUrl:'https://www.biography.com/.image/ar_1:1%2Cc_fill%2Ccs_srgb%2Cg_face%2Cq_auto:good%2Cw_300/MTE5NDg0MDU0OTQ1MDM5ODg3/charles-dickens-9274087-1-402.jpg',
imageSource:'Wikimedia Commons',
books: ['David Copperfield', 'A Tale of Two Cities']
},
{
name: 'William Shakespear',
imageUrl:'http://shakespeare.mit.edu/shake.gif',
imageSource:'Wikimedia Commons',
books: ['Hamlet', 'Macbeth', 'Remeo and Juliet']
}
]
class App extends Component {
constructor(){
super();
this.state=[{
turnData: '',
}]
this.getTurnData=this.getTurnData.bind(this);
}
getTurnData=(authors)=>{
const allBooks = authors.reduce(function (p,c){
return p.concat(c.books)
}, [])
const fourRandomBooks = shuffle(allBooks).slice(0,4)
const answer = sample(fourRandomBooks);
return{
books: fourRandomBooks,
author: authors.find((author)=>author.books.some((title)=>title===answer))
}
}
componentDidMount()
{
console.log("Inside componentDidMount"+this.getTurnData(authors));
this.setState([{ turnData: this.getTurnData(authors) }]);
}
render() {
return (
<div className="container-fluid">
<AuthorsQuiz data={this.state.turnData}/>
</div>
)
}
}
export default App;
AuthorsQuiz.js
import React, { Component } from 'react';
class AuthorsQuiz extends Component {
render() {
return (
<div className="container-fluid">
<Hero/>
<Turn books={this.props.data}/>
<Continue/>
</div>
)
}
}
const Hero=()=>{
return(
<div>
<div className="jumbotron jumbotron-fluid">
<div className="container">
<h1 className="display-4">Author Quiz by Smit Sanghvi</h1>
<p className="lead">This is a modified jumbotron that occupies the entire horizontal space of its parent.</p>
</div>
</div>
</div>
);
}
const Books=(props)=>{
return(
<div>
{props.title.name}
</div>
);
}
const Turn=(props)=>{
//console.log(props.books.imageUrl);
return(
<div className="row">
<div className="col-sm-5">
<img alt="pic" src={props.books.imageUrl}></img>
</div>
<div className="col-sm-7">
{props.books.map(title=>
<Books title={title} key={title}/>)}
</div>
</div>
);
}
const Continue=()=>{
return(
<div>
</div>
);
}
export default AuthorsQuiz;
答案 0 :(得分:0)
您可以做类似的事情
<div className="col-sm-5">
{props.books && <img alt="pic" src={books.imageUrl} />}
</div>
<div className="col-sm-7">
{props.books && books.map(title => <Books title={title} key={title} />)}
</div>
注意::<Turn />
函数组件是在调用<App />
的{{1}}之前呈现的,因此:
在您致电componentDidMount()
时,Turn.props.books.map(title=>...
仍然是this.state.turnData