文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

react如何改变组件状态

2023-07-04 20:05

关注

这篇文章主要介绍“react如何改变组件状态”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“react如何改变组件状态”文章能帮助大家解决问题。

在react中,可以利用setState()来修改组件的状态。setState()是用于更新组件状态state的方法,该方法可以对组件state的更改排入队列,也可获取最新的状态,语法为“this.setState( { 要修改的部分数据 } )”。

一、有状态组件和无状态组件

1.先理解一下什么是状态:

定义:

是用来描述事物在某一时刻的形态数据 ,  一般称为state。(可以简单理解为状态就是数据)
例如:9月23号时书的库存数量; 18岁时人的身高. vue中也有相关的概念

特点:

能被改变,改变了之后视图会有对应的变化 (双向数据绑定)

2.有状态组件和无状态组件

有状态组件:能定义state的组件。类组件就是有状态组件。

无状态组件:不能定义state的组件。函数组件又叫做无状态组件

注意:

2019年02月06日,React 16.8版本中引入了 React Hooks,从而函数式组件也能定义自己的状态了。【相关推荐:Redis视频教程、编程教学】

本文主要讲解类组件的状态

3.类组件的状态

1)定义状态

使用 state = { } 来做初始化

import React from "react";export default class Hello extends React.Component {  // 这里的state就是状态  state = {    list:  [{ id: 1, name: "给我一个div" }],    isLoading : true  };}

2)在视图中使用

 render() {    return (      <>            <h2>姓名-{this.state.name}</h2>            <ul>            {this.state.list.map((item) => (            <li key={item.id}>{item.name}</li>             ))}            </ul>        <div>{this.state.isLoading ? "正在加载" : "加载完成"}</div>      </>    );  }

二、事件绑定

1.格式

<元素 事件名1={ 事件处理函数1 }  事件名2={ 事件处理函数2 }  ></元素>\

注意

React 事件名采用驼峰命名法,比如:onMouseEnter、onFocus、 onClick ......

2.示例

import React from 'react'import ReactDOM from 'react-dom'const title = <h2>react中的事件</h2>export default class Hello extends React.Component {  fn() {    console.log('mouseEnter事件')  }  render() {    return (      <div            onClick = { () => console.log('click事件') }            onMouseEnte r = { this.fn }      </div>    )  }}const content = (  <div>    {title}    {<Hello />}  </div>)ReactDOM.render ( content , document.getElementById ('root') )

注意事项

别忘记了写this

三、事件处理-this指向问题

1.问题代码:

class App extends React.Component {        // 组件状态      state = {        msg: 'hello react'      }            // 事件处理函数      handleClick() {            console.log(this) // 这里的this是 undefined      }            render() {            console.log(this) // 这里的this是当前的组件实例 App                  return (              <div>                    <button onClick={this.handleClick}>点我</button>              </div>        )      }}

结果是这样:

2.原因:

class类和模块的内部,默认就是严格模式,所以不需要使用use strict指定运行模式。只要你的代码写在类或模块之中,就只有严格模式可用,所以类中的函数this指向了undefined

3.解决事件函数this指向:

方式1:

在事件处理程序外套一层箭头函数

缺点:需要在处理函数外额外包裹一个箭头函数, 结构不美观

优点:

前面讲过在 {this.handleClick ( )}这里面调用处理函数的时候不要加小括号,不然里面的程序会立即执行掉,现在在外面包裹一层箭头函数之后,不仅可以加上小括号,还能实现传参,后面会用到

class App extends React.Component {  state = {    msg: 'hello react'  }  handleClick () {    console.log(this.state.msg)  }  render () {    return (      <div>        <button onClick={ () => { this.handleClick ( ) }}>点我</button>      </div>    )  }}

方式2:使用bind

通过bind()方法改变函数this指向并不执行该函数的特性解决

class App extends React.Component {  state = {    msg: 'hello react'  }  handleClick () {    console.log(this.state.msg)  }  render () {    return (      <div>        <button onClick={ this.handleClick.bind (this) }>点我</button>      </div>    )  }}

方式3:

在class中声明事件处理函数的时候直接使用箭头函数

class App extends React.Component {  state = {    msg: 'hello react'  }  handleClick = () => {    console.log(this.state.msg)  }  render() {    return (      <div>        <button onClick={this.handleClick}>点我</button>      </div>    )  }}

优点:

代码简洁,直观,使用最多的一种方式

四、修改组件的状态

注意:

不能通过直接修改state中的值来让视图变化 ! ! !
通过this.setState()方法修改

在react中,setstate是用于更新组件状态state的方法;setState()将对组件state的更改排入队列,并通知React需要使用更新后的state重新渲染此组件及其子组件。

1.语法:

语法:this.setState( { 要修改的部分数据 } )
这是继承自React.Component的修改类组件状态的方法

state = {    count: 0,    list: [1, 2, 3],    person: {      name: 'jack',      age: 18    }  }    // 【不推荐】直接修改当前值的操作:  this.state.count++  ++this.state.count  this.state.count += 1  this.state.count = 1  this.state.list.push(4)  this.state.person.name = 'rose'    // 【推荐】不是直接修改当前值,而是创建新值的操作:  this.setState({    count: this.state.count + 1,    list: [...this.state.list, 4],    person: {      ...this.state.person,    // 要修改的属性,会覆盖原来的属性,这样,就可以达到修改对象中属性的目的了        name: 'rose'    }  })

五、表单处理-受控组件

示例代码:

class App extends React.Component {  state = {    msg: 'hello react'  }  handleChange = (e) => {    this.setState({      msg: e.target.value    })  }   // value 绑定state 配合onChange事件双向绑定  render() {    return (      <div>        <input type="text" value={this.state.msg} onChange={this.handleChange}/>      </div>    )  }}

注意事项

使用受控组件的方式处理表单元素后,状态的值就是表单元素的值。即:想要操作表单元素的值,只需要通过this.setState( { 要修改的部分数据 } )操作对应的状态即可

六、表单处理-非受控组件-ref

示例代码:

import { createRef } from 'react'class Hello extends Component {  txtRef = createRef()  handleClick = () => {    // 文本框对应的 DOM 元素    // console.log(this.txtRef.current)    // 文本框的值:    console.log(this.txtRef.current.value)  }  render() {    return (      <div>        <input ref={this.txtRef} />        <button onClick={handleClick}>获取文本框的值</button>      </div>    )  }}

关于“react如何改变组件状态”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识,可以关注编程网行业资讯频道,小编每天都会为大家更新不同的知识点。

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯