当前位置: 首页 > news >正文

React实现Vue的watch监听属性

在 Vue 中可以简单地使用 watch 来监听数据的变化,还能获取到改变前的旧值,而在 React 中是没有 watch 的。

React中比较复杂,但是我们如果想在 React 中实现一个类似 Vue 的 watch 监听属性,也不是没有办法。

在React类组件中实现watch监听属性

我们可以使用 componentDidUpdate 函数来监听组件属性的变化,来模拟于 Vue 中的watch。

例如,我们有一个组件 MyComponent,其中有一个属性 name:

class MyComponent extends React.Component {state = {name: 'John'}componentDidUpdate(prevProps, prevState) {if (prevState.name !== this.state.name) {console.log('Name changed to:', this.state.name)}}render() {return (<div>My name is {this.state.name}</div>)}
}

        在 componentDidUpdate 函数中,我们可以比较当前状态和之前的状态,当 name 属性发生变化时,就可以执行某些操作,例如打印日志。

        需要注意的是,在 componentDidUpdate 函数中,我们还需要比较 prevprops 和 this.props ,以确保只有 name 属性发生变化时才会执行我们的操作:

componentDidUpdate(prevProps, prevState) {if (prevProps.name !== this.props.name || prevState.name !== this.state.name) {console.log('Name changed to:', this.state.name)}
}

        这样我们就可以在 React 类组件中实现类似于 Vue 中 watch 的功能,监听组件属性的变化并执行相应的操作。

在React函数组件中实现watch监听属性 

        在 React 中默认函数组件不能使用生命周期。需要配合 React16.8新增的 Hook -- useEffect 才能实现。使用 React 实现类似 Vue 中的 watch 监听属性可以通过使用 useEffect hook来完成。

         1、引入useEffect hook:        

import { useEffect } from 'react';

        2、 在组件中定义要监听的属性:

const [data, setData] = useState({ name: 'John', age: 25 });
const [name, setName] = useState('');// 监听data对象的name属性的变化
useEffect(() => {console.log(`name: ${data.name}`);
}, [data.name]);

        3、监听属性的变化:

// 修改data对象的name属性的值
setData({...data, name: 'Lucy'}); 

        当data对象的name属性发生改变时,useEffect 会触发执行其回调函数,并打印出新的值。

        需要注意的是,由于React 中所有组件状态都是不可变的,所以我们在修改要监听的属性时需要使用深拷贝,确保不会影响到原始的值。

 

 

http://www.lryc.cn/news/91975.html

相关文章:

  • axios、跨域与JSONP、防抖和节流
  • macOS Ventura 13.5beta2 (22G5038d)发布
  • jwt----介绍,原理
  • Three.js--》实现3d水晶小熊模型搭建
  • 《阿里大数据之路》研读笔记(1)
  • Logback 日志框架详解
  • BIO、NIO、AIO 有什么区别?
  • nginx和tomcat负载均衡、静态分离
  • 用AI写出的高考作文!
  • chatgpt赋能python:Python屏幕输入介绍:了解命令行输入的基本知识
  • bert中文文本摘要代码(1)
  • 为何溃坝事故频发,大坝安全如何保障?
  • 第十九章_手写Redis分布式锁
  • 电路设计【8】原理图中VCC、VDD、VEE、VSS、VBAT各表示什么意思
  • Volatile、Synchronized、ReentrantLock锁机制使用说明
  • 港联证券|AI概念股继续活跃 科创50指数逆势走高
  • 分布式事务一 事物以及分布式事物介绍
  • 【十四】设计模式~~~行为型模式~~~中介者模式(Java)
  • css3--nth-child的用法
  • 【假捻发加工生产工单下达】
  • Go for-range VS for
  • 大数据教程【01.01】--大数据介绍及开发环境
  • 文件阅览功能的实现(适用于word、pdf、Excel、ppt、png...)
  • 面试-RabbitMQ常见面试问题
  • 使用VBA在单元格中快速插入Unicode符号
  • PyTorch 深度学习 || 专题六:PyTorch 数据的准备
  • 迅为RK3568开发板2800页手册+220集视频
  • 模拟电子 | 稳压管及其应用
  • 使用大型语言模(LLM)构建系统(二):内容审核、预防Prompt注入
  • springboot---mybatis操作事务配置的处理