如何理解React的state、props、super()和super(props)

state

一个组件需要显示什么,怎么显示内容,都是由数据状态和外部参数决定的。

state就是这个数据状态。

当需要修改状态值的时候,通过调用setState,实现更新组件内部数据的问题。

setState的第一个参数有两种形式:一种是对象,这个对象里面包含了需要更新的状态字段;另一种是函数,这个函数接收当前状态作为入参,并且返回一个对象来更新组件的状态。

setState还可以接收第二个参数,它是一个函数,会在setState调用完成并且组件开始更新时被调用,在这里可以用来监听渲染是否完成。

props

React的核心思想就是组件化,页面被切分为一些独立的、可复用的组件,组件概念上就是函数,接收一个参数作为入参,这个参数就是props,组件外部传入的数据都在props上。

state和props都是对象,用来保存信息,props和state都能触发组件更新。

不同的是:

  1. props是组件外部传入的,然而state是组件内部自己管理的。
  2. props在组建内部不可修改,但是state可以修改;
super()

在class继承类的时候,通过super关键字来来实现调用父类,super替代父类的构建函数。

为什么要调用super呢,因为子类是没有自己的this对象,它只能通过继承父类的this,然后对它进行加工。super方法就是将父类的this继承给子类。没有调用super,子类就得不到this对象,那么使用this就会报错。

在React的类组件是通过继承React.Component,所以在constructor构造函数里面调用super方法才能初始化thi是。

如果super方法没有传入props,类组件会在构造函数生成实例后,再给this.props赋值。所以构造函数内this.props为undefined。

相关推荐
史迪仔011211 分钟前
[QML] Qt6/Qt5四大渐变效果实战指南
开发语言·前端·c++·qt
果壳~12 分钟前
【Uniapp】【rich-text】富文本展示以及图片预览功能解决方案
前端·javascript·uni-app
z194089206614 分钟前
在线生成背景:字号层级怎么做才像「正式物料」
前端·javascript·html
skilllite作者17 分钟前
GEO 是什么:从搜索引擎到「对话式答案」的信息可见性
java·前端·笔记·安全·搜索引擎·agentskills
Hello--_--World21 分钟前
React:useState 函数式更新、useContext 全解析、useReducer 深度解析
前端·react.js·前端框架
李白的天不白23 分钟前
vue优化建议
前端·javascript·vue.js
前端老石人26 分钟前
Chrome DevTools 调试入门:从零开始排查 CSS 问题
前端·css·chrome devtools
恋猫de小郭29 分钟前
经典,Flutter iOS 又修复了一个构建问题,还是很抽象
android·前端·flutter
invicinble34 分钟前
前端框架使用vue-cli(总篇章介绍)
前端·vue.js·前端框架
QD_ANJING38 分钟前
普及一下五月AI前端面试需要达到的强度....
前端·javascript·vue.js·人工智能·面试·职场和发展