react组件状态

一个前提:在react hook出来之前,函数式组件是没有自己的状态的,所以我们统一通过类组件来讲解

1. 初始化状态

• 通过class的实例属性state来初始化

• state的值是一个对象结构,表示一个组件可以有多个数据状态

html 复制代码
React.Component{
  // 初始化状态
  state = {
    count: 0
  }
  render() {
    return <Button>计数器</Button>
  }
}

2. 读取状态

• 通过this.state来获取状态

classCounterextendsReact.Component{

html 复制代码
  // 初始化状态
  state = {
    count: 0
   }
  render() {
    // 读取状态
    return <Button>计数器{this.state.count}</Button>
  }
}

3. 修改状态

• 语法

this.setState({ 要修改的部分数据 })

• setState方法作用

• 修改state中的数据状态

• 更新UI

• 数据驱动视图,也就是只要修改数据状态,那么页面就会自动刷新,无需手动操作dom

• 不要直接修改state中的值,必须通过setState方法进行修改

html 复制代码
React.Component{
  // 定义数据
  state = {
    count: 0,
    abled: false,
  }
  // 定义修改数据的方法
  setCount = () => {
    this.setState({
      count: this.state.count+ 1
    })
  }
  // 使用数据 并绑定事件
  render () {
    return
   		<Button onClick={this.setCount} disabled={this.state.abled}>
    		{this.state.count}
    	</Button>
  }
}
相关推荐
徐安安ye几秒前
FlashAttention前端优化:Token合并、MergeNet与冗余计算消除
前端
吃炸鸡的前端3 分钟前
react-hook-from从入门到精通
前端·javascript·react.js
CairBin7 分钟前
TiphiaPress——Rust+React构建的个人博客框架
react.js·rust·tiphiapress
来恩100320 分钟前
jQuery对Ajax的支持
前端·ajax·jquery
KaMeidebaby22 分钟前
卡梅德生物技术快报|抗体的制备与纯化:分子实验实操:番茄 sHSP 重组表达与抗体的制备与纯化工艺
前端·数据库·人工智能·其他·算法·百度·新浪微博
IT_陈寒25 分钟前
Vite热更新把我整不会了,原来还要这样配!
前端·人工智能·后端
恋猫de小郭25 分钟前
AI 时代,谷歌都在 Android 官方做了哪些支持?
android·前端·flutter
zzqssliu34 分钟前
跨境独立站多端适配开发:多语言+多货币+跨平台同步技术实战
前端·javascript·php
Chengbei1135 分钟前
AI赋能Chrome MCP × JS逆向Skill自动化JS逆向助力挖洞与绕过实战(小白也能学会)
javascript·人工智能·chrome·网络安全·自动化·系统安全·安全架构
怕浪猫38 分钟前
Electron 开发实战(五):文件系统与本地数据持久化全解
前端·javascript·electron