- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
根据本页http://busypeoples.github.io/post/react-component-lifecycle/组件的 render 方法在 componentWillMount
和 componentDidMount
方法之间的其他地方被调用。
但是组件生命周期的 react.js 文档在这里 https://facebook.github.io/react/docs/component-specs.html表示所有子事件的 componentDidMount
方法在父事件之前被调用。我可以理解 componentDidMount
可以在渲染任何子组件后调用,但是运行时如何知道在渲染之前调用哪些子组件 componentWillMount
函数?或者我是否正确地假设 componentWillMount
首先为父事件调用,然后为子事件调用(与 componentDidMount
不同)?
谢谢!
最佳答案
好的。所以就这样吧。如果您有一个简单的结构,其中有一个父项和 2 个子项,如下所示:
<Parent>
<Child/>
<Child/>
</Parent>
那么事件触发的顺序将是:
<Parent> componentWillMount()
<Parent> render()
, 开始渲染 child <Child> componentWillMount()
第一个 child <Child> render()
第一个 child <Child> componentWillMount()
第二个 child 的<Child> render()
第二个 child 的<Child> componentDidMount()
第一个 child 的(这些只会在树中的最后一个渲染运行后开始)<Child> componentDidMount()
第二个 child 的<Parent> componentDidMount()
(这个只有在它的最后一个 child 运行后才会运行 componentDidMount
)你可以找到一个codepen example here .
关于javascript - React.js 中 componentWillMount 调用的顺序,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37121145/
在我的代码中,我没有任何显式使用 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 中进行。
我是一名优秀的程序员,十分优秀!