5

我创建了一个应用程序来学习 ReactJS。不幸的是,当我尝试使用上下文时,我在渲染时遇到了 1 个错误,但我的应用程序编译得很好。

这是我的代码:

import React, {Component} from 'react';

const LoginContext = React.createContext(null);

const user = {
    isLoggedIn: true,
    username: 'test',
};

class App extends Component {
    constructor(props) {
        super(props);
        this.state = {
            isLoggedIn: false,
            user: user,
        };
    }

    render() {
        return (
            <LoginContext.Provider user={this.state.user}>
                 <Welcome/>
            </LoginContext.Provider>
        );
        }
    }

class Welcome extends Component {
    render() {
        return (
            <div>
                <WelcomeText/>
            </div>
        );
    }
}

class WelcomeText extends Component {
    render() {
        return (
            <LoginContext.Consumer>
                <div>
                    {(user) => (<p>{user.username}</p>)}
                </div>
            </LoginContext.Consumer>
        );
    }
}

export default App;

这是错误: updateContextConsumer http://localhost:3000/static/js/bundle.js:20927:23

  20924 | {
  20925 |   ReactCurrentOwner.current = workInProgress;
  20926 |   ReactDebugCurrentFiber.setCurrentPhase('render');
> 20927 |   newChildren = render(newValue);
        |                 ^  20928 |           ReactDebugCurrentFiber.setCurrentPhase(null);
  20929 | } // React DevTools reads this flag.
  20930 | 

你能帮我解决这个问题吗?

4

2 回答 2

4

ContextProvider需要一个叫做value而不是的道具user

  <LoginContext.Provider value={this.state.user}>
        <Welcome/>
  </LoginContext.Provider>

上下文消费者也有孩子作为一个功能,而不是 div

class WelcomeText extends Component {
    render() {
        return (
            <LoginContext.Consumer>
                  {(user) => (<div><p>{user.username}</p></div>)}
            </LoginContext.Consumer>
        );
    }
}
于 2018-07-18T10:17:26.040 回答
2

我目前正在研究 React-16.8.6 并且有一个有趣的错误。我不确定这是否是已知问题,但每当我在两个字符“}”和“<”之间有空格时,我都会遇到同样的错误,正如你在第 30 行看到的那样。

在 (1) 删除空格或 (2) 用 完全换行后,它得到了解决。

尽管我非常喜欢 React,但它并不完美,我们可以一起让它变得更好。

有空间的时候

删除空间后

于 2019-07-17T17:38:13.020 回答