- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我在安装组件之前调用 API,但我的代码调用 API 两次。我的要求是在成功调用 API 后显示年份数据(它将返回年份数据)。如果我在 componentWillMount 中使用 setState 函数,那么它不应该调用 render 方法,但在我的例子中,render 函数也被调用了几次。
componentWillMount(){
// Year api call
var oauth=GetAuthToken()
if(this.props.options.apiName === 'year__c' ){
var access_token=oauth.then((data) => {
var temp
temp=GetYear(data.access_token)
temp.then((obj) => {
this.setState({
year:obj
})
})
})
}
}
最佳答案
您遇到的问题是您的设置状态基于正在解决的 promise 。在普通的 componentWillMount
中,您设置状态,它会更新状态,然后第一次调用 render()。当您将异步 api 调用引入图片时,会发生什么:
componentWillMount
被执行,调用 API 并创建 Promise,当 Promise 等待解析代码继续执行时,React 在组件上执行 Render() 方法。在渲染 Promise 后的某个时刻,解决了,然后调用 setState 并且由于组件已经被渲染,那么由于状态的变化它将不得不重新渲染。
两者之间的主要区别在于:如果您只是在componentWillMount
中setState
,那么它将在渲染发生之前发生。如果您将 setState
作为正在解析的 Promise 的一部分,它将在组件呈现后发生,从而导致多次呈现。
关于javascript - componentWillMount 执行两次,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41110103/
在我的代码中,我没有任何显式使用 componentWillMount,但在运行 webpack 时我仍然看到一些警告. react-dom.development.js:12386 Warning:
据我所知,componentWillMount 唯一可以做而 constructor 不能做的就是调用 setState。 componentWillMount() { setState({
我正在react组件的componentWillMount函数中发出ajax请求。我有一个状态变量。我将此变量的状态设置为 ajax 调用的响应。 this.setState({state_varia
在 ReactJs 中,我们可以使用 componentWillMount 做哪些不能通过构造函数做的事情?两者都在组件渲染之前调用一次。 import React from 'react'; cla
我在reactjs 中的状态方面面临一些困难。据我所知,componentWillMount 是在渲染组件之前使用 ajax 调用加载数据的地方。我有一个简单的项目,它用加载的数据填充面板堆栈并将其显
我正在创建一个内部布局。我是从另一个场景看到这个场景的。所以一开始就渲染了另一个布局。当我进入第二个场景(带有 TextInput 标签)后,我收到警告,例如: componentWillMount
触发服务器调用以在 componentWillMount 生命周期方法中获取数据是一个不好的做法吗? 以及为什么最好使用 componentDidMount。 最佳答案 更新: componentWi
首先,我是 React 新手,这是我的第一个项目。 我正在创建一个基本的博客应用程序,我的应用程序类如下所示: var App = React.createClass({ getInitial
我正在学习 React。我在 vanilla JS 中有一个小函数,它随机生成一个给定的图像。由于它是随机的,并且没有(有意)保存到任何状态,因此每个状态更改也会更改图像,这是我试图避免的。该图像将用
如果已经登录,我正在努力重定向到主页。我正在使用 ping 获取登录信息,如果成功,我将设置一个状态,该状态将在渲染和重定向中进行检查。但几秒钟后它会显示登录页面,然后重定向到主页。我做错了什么? e
对于react-native,我想使用componentWillMount而不使用类 await Font.loadAsync({ gotham_medium: require("../.
正如官方文档所说, componentWillMount 现已弃用,建议放置用于此生命周期方法的任何代码都放入构造函数中。 老实说我不知道该怎么做。我已经得到了用于 componentWillMo
我在安装组件之前调用 API,但我的代码调用 API 两次。我的要求是在成功调用 API 后显示年份数据(它将返回年份数据)。如果我在 componentWillMount 中使用 setState
我的 componentWillMount() 每次切换路由时都会被调用。 有没有其他方法可以处理商店状态的变化? 当我第一次使用这两个功能时没问题,但是当我切换路线并返回并尝试再次使用它们时,我收到
我正在使用 React.js,如您所知,componentWillMount() 将被弃用。我想替换我的 componentWillMount。 我要把它的逻辑移到constructor中。在 com
一个类用于拦截 axios 错误。为了绑定(bind)箭头函数,正在使用 componentDidMount()。现在我需要从服务器初始化数据,所以我必须使用 componentWillMount()
我有一个关于何时 componentDidMount 以及何时触发的问题,我是使用 React 的新手,并且文档的示例很模糊。为什么我的组件没有触发? var App = React.createCl
从昨天开始(我认为)我开始收到来自 React 的警告: Warning: componentWillMount has been renamed, and is not recommended fo
我收到四个无法在控制台中最小化的重大警告。这些警告来 self 的理解,不是因为我做错了什么,而是因为react-router-dom和react-select使用了已弃用的componentWill
如果我有一个需要一些设置的 React 组件(例如计时器或 WebAudio API 等),我很难决定初始化应该在 constructor 中进行还是在 componentWillMount 中进行。
我是一名优秀的程序员,十分优秀!