将数据作为 props 传递时未定义
2018-06-18
69
我在
user.login
和
user.bio
处收到
undefined
,无法将数据从 App.js 传递到
UserInfo
组件。由于我没有传递任何状态,所以只是传递了 props。
App.js
render() {
return (
<div>
<nav className="uk-navbar-container uk-margin" uk-navbar="true">
<div className="uk-navbar-left">
<a className="uk-navbar-item uk-logo" href="/"> Github search
<span uk-icon="icon: github; ratio: 2.2" className="uk-margin-large-right"></span>
</a>
<div className="uk-navbar-item uk-navbar-right">
<form onSubmit={this.submitUser}>
<input className="uk-input uk-form-width-medium"
type="text" placeholder="Github UserName...."
id="username" onKeyUp={this.onChange} ref="username"></input>
<button className="uk-button uk-button-primary">Search
<span uk-icon="search" className="uk-margin-small-right"></span>
</button>
</form>
</div>
<div className="uk-navbar-item uk-navbar-right"></div>
</div>
</nav>
<div className="uk-container-large">
<UserInfo name={this.props.username} />
</div>
</div>
);
}
UserInfo.js
import React, { Component } from 'react';
class UserInfo extends Component {
constructor(props) {
super(props)
this.state = { userList: [] }
}
componentDidMount() {
console.log('in child =' + this.props.name)
fetch('https://api.github.com/users/${this.props.name}')
.then(res => res.json())
.then(userList => {
this.setState({ userList: userList })
console.log('data is :' + userList);
});
}
render() {
if (!this.state.userList) {
return (<div className="uk-child-width-1-3@s uk-grid-match">Loading...</div>)
}
const user = this.state.userList;
return (
<div className="uk-child-width-1-3@s uk-grid-match" uk-grid="true">
<h3> {user.login} </h3>
<h3>{user.bio}</h3>
</div>
);
}
}
export default UserInfo;