开发者问题收集

将数据作为 props 传递时未定义

2018-06-18
69

我在 user.loginuser.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  &nbsp;
                          <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>
                            &nbsp;&nbsp;
                            <button className="uk-button uk-button-primary">Search &nbsp;
                            <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;
1个回答

调用 fetch 库时字符串连接错误,您可以使用反引号而不是正常的顶点

fetch(`https://api.github.com/users/${this.props.name}`)

或使用普通的旧连接

fetch('https://api.github.com/users/' + this.props.name)

否则 this.props.name 将不会被解释为实际变量,最终将得到 404

在此处输入图片说明

Karim
2018-06-18