我正在从一个文件导出常量并将其导入另一个文件,如下所示:
常数.js
export const radio = {
id: 0,
name: 'station name',
encodedName: 'stationName',
url: 'http://www.some-station.io/',
src: 'http://127.0.0.1:80/autodj',
};
App.js
import React, { Component } from 'react';
import RadioService from './services/radio';
import { radio } from './constants';
class App extends Component {
constructor() {
super();
this.state = {
stream: {
np: undefined,
src: undefined,
playing: false
}
};
}
componentWillMount() {
this.startStream();
}
startStream = () => this.setState({ stream: { np: radio.name, src: radio.src } });
render() {
return (
<div>
<h4>Hello World...</h4>
</div>
);
}
}
export default App;
我希望我的初始状态是在构造函数中设置的,然后在componentWillMount上,我希望使用常量文件中的值设置状态,然后再围绕组件和流添加进一步的逻辑。
但是,我发现,我的状态没有被更新,如果我在调用setState之后记录控制台日志,状态仍然没有定义,如果我引入一个方法,需要state中的值,那么在执行堆栈的后面,它没有被设置。
例如:
startStream = () => {
this.setState({ stream: { np: radio.name, src: radio.src } });
this.exampleMethod();
};
exampleMethod = () => console.log(this.state);
这返回:
{stream: {…}}stream: {np: undefined, src: undefined, playing: false}
然而,我可以在构造函数中设置一些值,但是尝试设置进一步的状态是不适用的
例二:
class App extends Component {
constructor() {
super();
this.state = {
stream: {
np: radio.name,
src: radio.src,
playing: false
}
};
}
componentWillMount() {
this.startStream();
}
startStream = () => {
this.setState({ ...this.state, stream: { playing: true } });
this.exampleMethod();
};
setState是异步的,因此如果在之后立即使用console.log,则不会获得新状态。
reactjs中的设置状态为异步或同步
setState
是一个异步函数。不能期望在setState语句之后立即更新状态。
但是,您可以通过以下任一方式检查状态:
>
在render()方法中放置console.log(this.state)
。
或者在setState
this.setState({…this.state,流:{播放:true}},()=
所以我有这个: 只是一个数组的数字例如然而没有给出正确的总数,但?我甚至放了一个超时延迟,看看这是否解决了问题。任何明显的还是我应该发布更多的代码?
我猜这可能与从父级打开有关,但我有其他组件,它们内部的状态发生变化,所以我有点困惑,为什么这个组件不尊重它的新状态。 谢谢
问题内容: 所以我有这个: newDealersDeckTotal只是一个数字数组,例如,但是没有给出正确的总数,但是呢?我什至设置了超时延迟,以查看是否可以解决问题。任何明显的还是我应该发布更多代码? 问题答案: 通常是异步的,这意味着在您处于状态时,它尚未更新。尝试将日志放入方法的回调中。状态更改完成后执行:
我有一个简单的组件 问题是我需要添加什么
我想问一下,为什么在执行事件时,我的状态没有改变。我已经搜索到需要在构造函数中绑定函数,但是状态仍然没有更新。 下面是我的代码:
问题内容: 我想问为什么在执行onclick事件时状态没有变化。我已经搜索了一段时间,我需要在构造函数中绑定onclick函数,但状态仍未更新。这是我的代码: 问题答案: 这个回调真的很混乱。只需使用async await代替: