react 之 state 对象

简介: 首先,在 react 中,通过类来构建 react 组件时,可以在类的构造函数 constructor 中可以使用 react 的属性 state,属性 state 是一个对象,在对象中可以定义组件需要的属性和属性值,比如下面的例子:

首先,在 react 中,通过类来构建 react 组件时,可以在类的构造函数 constructor 中可以使用 react 的属性 state,属性 state 是一个对象,在对象中可以定义组件需要的属性和属性值,比如下面的例子:


import React from "react";
import reactDom from "react-dom";
class App extends React.Component{
    constructor(){
        super();
        this.state = { num: 0 };
    }
}

接下来,我们就可以在 react 组件内部的 render 方法定义虚拟 DOM 元素时使用挂载在类组件上的 state 对象。 例如:



class App extends React.Component {
  render() {
    return (
      <React.Fragment>
        <p>{this.state.num}</p>
      </React.Fragment>
    );
  }
}

再者,我们通过 React-Dom 的 render 方法将创建好的类组件渲染到页面上,代码如下:


reactDom.render(<App></App>,window.root);

这样,页面上就可以看到,在 root 节点下面已经有一个子节点 p,并且 p 节点显示的内容为 0。


15891c3bb40a8a5d360bafb1f827aa019598f11b

react setState 修改组件状态

在 react 中提供了一个 setState 方法,这个方法主要用来修改组件的状态,调用这个方法后,react 将会调用 react-dom 中的 render 方法重新渲染页面。

那么,这个 setState 方法该在哪里使用?并且如何使用呢? 下面,我们就基于上面的例子进行扩展来说明 setState 该如何使用:

首先我们在需要进行渲染的虚拟 DOM 元素上增加 2 个按钮:


class App extends React.Component {
  render() {
    return (
      <React.Fragment>
        <p>{this.state.num}</p>
        <button onClick={this.add}>增加</button>
        <button onClick={this.remove}>删除</button>
      </React.Fragment>
    );
  }
}

接下来,我们给"增加"按钮添加一个 add 方法,当点击这个"增加"按钮时给 state 对象上的 num 属性的属性值增加 1。


 add = () => {
    // 这里我们采用定时器的方式,不停的调用setState给num属性赋值
    this.timer = setInterval(() => {
      // prevState是react自带的,表示的是没设置之前的状态
      this.setState(prevState => ({ num: prevState.num + 1 }));
    },1000);
  };

这时我们去页面上点击"增加"按钮,触发 add 方法,num 属性的值就不停的修改:

5ade6435a9338b5101148824fb4a6e566463373e

现在,我们还有一个"删除"按钮没有完成,这里删除按钮的思路是将整个组件移除掉,让我们一起来完成 remove 事件吧:


// 移除虚拟DOM节点,销毁组件
remove = () => {
    // 移除指定DOM节点上的组件
    reactDom.unmountComponentAtNode(window.root);
};

这时我们去页面上点击"增加"按钮,触发 add 方法,然后再点击"删除"按钮,触发 remove 方法,此时我们可以发现,root 的子节点全部都删除,但是不好意思,浏览器 console 中出现了一个错误,让我们一起来看看吧:

6be7cb9fb0f9c6e4038072f281565fc11efff8f3

很明显,这是react给出的一个提示,说明我们的代码中出现的错误,具体的含义是:

"无法在未安装的组件上调用SETStATE(或FracePoPoT)。这是一个NOP,但是它指示了应用程序中的内存泄漏。若要修复,请取消组件Wun卸除方法中的所有订阅和异步任务。"

意思是我们在调用remove方法的时候,已经将整个组件都从页面上移除了,页面上已经没有了这个组件,但是我们的add方法是通过一个定时器不停的修改这个组件的状态值,但是组件都已经不存在了,所以就会报这样的一个警告,所以要解除这个警告需要在组件卸载之前将定时任务给清空。

因此,在这里,我们需要用到react生命周期里提供的一个方法:componentWillUnmount。这个方法在组件从DOM中移除时立刻被调用。



componentWillUnmount(){
    clearTimeout(this.timer);
}

now,我们再来看看页面上移除组件后会不会触发警告:

d39b4ab8b92934646a71596104d715e55071e7f5

好了,关于react中的state对象先整理到这里,欢迎大家一起交流、沟通。



原文发布时间为:2018年06月28日
原文作者: tenor
本文来源: 掘金  如需转载请联系原作者




相关文章
|
2月前
|
存储 前端开发 API
第六章 react组件实例中三大属性之State
第六章 react组件实例中三大属性之State
|
15天前
|
存储 前端开发 JavaScript
前端框架与库 - React基础:组件、Props、State
【7月更文挑战第12天】React是JavaScript库,专注UI构建,基于组件化。组件是UI模块,可函数式或类定义。Props是组件间安全传递数据的只读参数,用defaultProps和propTypes保证正确性。State则是组件内部可变数据,用于驱动更新。使用setState()确保正确变更和渲染。了解并妥善处理这些概念是高效React开发的基础。
|
1月前
|
JavaScript 前端开发 算法
虚拟DOM是React的关键技术,它是个轻量的JS对象树,模拟实际DOM结构。
【6月更文挑战第27天】虚拟DOM是React的关键技术,它是个轻量的JS对象树,模拟实际DOM结构。当状态改变,React不直接修改DOM,而是先构建新的虚拟DOM树。通过 diff 算法比较新旧树,找到最小变更,仅更新必要部分,提高性能,避免频繁DOM操作。虚拟DOM还支持跨平台应用,如React Native。它优化了更新流程,简化开发,并提升了用户体验。
22 1
|
21天前
|
JavaScript
react18【系列实用教程】useRef —— 创建 ref 对象,获取 DOM (2024最新版)
react18【系列实用教程】useRef —— 创建 ref 对象,获取 DOM (2024最新版)
20 0
|
22天前
|
前端开发 JavaScript
react18【系列实用教程】useState —— 声明响应式变量(2024最新版)含useState 的异步更新机制,更新的合并,函数传参获取更新值,不同版本异步更新差异,更新对象和数组
react18【系列实用教程】useState —— 声明响应式变量(2024最新版)含useState 的异步更新机制,更新的合并,函数传参获取更新值,不同版本异步更新差异,更新对象和数组
37 0
|
1月前
|
存储 前端开发 JavaScript
React中有效地使用props和state来管理组件的数据和行为
React中有效地使用props和state来管理组件的数据和行为
|
2月前
react+typescript给state和props定义指定类型
react+typescript给state和props定义指定类型
49 1
|
2月前
|
前端开发
「React」很多人在滥用 state
「React」很多人在滥用 state
|
2月前
|
存储 前端开发
react中 state和props的区别
react中 state和props的区别
34 0
|
2月前
|
前端开发
React State(状态)
React State(状态)

热门文章

最新文章