vue转react useEffect的全过程

作者:亦晓寒 时间:2024-05-02 16:32:22 

vue转react useEffect

useEffect用于处理组件中的effect,通常用于请求数据,事件处理,订阅等相关操作。

useEffect的第二个参数

1.当useEffect没有第二个参数时

vue转react useEffect的全过程

vue转react useEffect的全过程

通过这个例子可以看到useEffect没有第二个参数时不停的在调用

2.当useEffect第二个参数为空数组时

vue转react useEffect的全过程

vue转react useEffect的全过程

通过这个例子可以看出来useEffect在调用一次后就不再调用

3.当useEffect第二个参数为变量时

vue转react useEffect的全过程

通过这个例子可以看出来useEffect在每次count发生变化时调用

useEffect的使用

vue转react useEffect的全过程

上面的例子可以看出来使用useEffect和和class component使用生命周期函数时的区别,使用useEffect将每次count变化的数据都打印出来,而使用componentDidUpdate打印了最后一个数据很多次,因为class component里面的state随着render是发生变化的,而useEffect里面的所有东西都是每次render独立的。

useEffect清除

vue转react useEffect的全过程

useEffect通过return进行一些清除。

vue转react useEffect的全过程

例如官方文档里面的例子,当props.friend.id发生变化时,可以进行清除工作

vue2转战React Hooks实践

从vue2转战到react16.12, 还是有好多差异的。总结起来:

开发思路上

vue是基于data的双向绑定,数据流在model(data)<=>view(template)中是双向流动关系。所以修改data, 绑定该data的视图会随之修改;修改view,data中的数据也会随之修改(当然,这种情况只针对于可输入类型的表单元素),然后再配合钩子函数created、mount、activated、deactivated、beforeDestroy(还有vue-router提供的beforeRouteLeave等)等在某个时刻自动触发一些业务逻辑。

react(16.8版本后,官方推荐react hooks开发方式)则是单向数据流动,通过useState声明变量,视图绑定state。类似钩子函数的工作,react使用useEffect来实现,通过不同的依赖项,实现不同的钩子函数作用。react开发上,就像堆积木,开发的所有东西都是组件,所以组件化更彻底;vue则是以page划分的,然后组件是引入到page中的。

代码组织结构上

vue是以.vue为模块组织代码的,一个.vue模块中包含template、script、style来分别实现视图、业务逻辑、样式的编写。

react是以.jsx为模块组织代码的,一个.jsx模块中template都是嵌入在script中的,style另外引入,更像是所有代码都是在函数中实现的。 

import React, { useState, useEffect, useCallback } from 'react';
import style from './index.less';
import CardTest from '../components/CardTest/index';
import { getInfo } from '../../../api/api';
const CardTest = () => {
const [info, setInfo] = useState({});
useEffect(() => {
  requestData();
}, []);
// 请求数据
const requestData = () => {
  const requestParm = "XXX";
  getInfo(requestParm)
    .then(res => {
      const { data = {} } = res;
      setInfo(data);
    })
    .catch(err => {});
};
return (
  <div className={style.wrap}>
    <div className="list">
      <CardTest  data={info} />
    </div>
  </div>
);
};
export default CardTest;

以上为个人经验,希望能给大家一个参考,也希望大家多多支持asp之家。 

来源:https://www.jianshu.com/p/2115c3253e98

标签:vue,react,useEffect
0
投稿

猜你喜欢

  • ASP中Global.asa使用方法说明

    2007-11-03 13:18:00
  • Bootstrap-table使用footerFormatter做统计列功能

    2024-04-29 13:13:01
  • python读写LMDB文件的方法

    2021-12-17 15:12:37
  • Python操作数据库之数据库编程接口

    2024-01-25 01:55:41
  • python基础篇之pandas常用基本函数汇总

    2021-09-06 20:42:22
  • 函数式编程让JS更优美

    2008-06-10 12:40:00
  • Python数据分析之 Matplotlib 散点图绘制

    2021-09-19 07:05:46
  • Python实现的端口扫描功能示例

    2022-06-25 10:42:04
  • SQL Server小知识:Processor Affinity

    2008-11-24 20:50:00
  • PHP echo()函数讲解

    2023-06-05 18:50:54
  • 通过python连接Linux命令行代码实例

    2023-01-25 23:10:33
  • Python批量转换文件编码格式

    2021-10-07 05:01:22
  • 探究MySQL优化器对索引和JOIN顺序的选择

    2024-01-14 14:36:00
  • JS实现匀加速与匀减速运动的方法示例

    2024-06-07 15:27:36
  • Javascript学习笔记之 函数篇(一) : 函数声明和函数表达式

    2024-04-23 09:08:58
  • python optparse模块使用实例

    2021-02-03 22:01:36
  • 使用 MySQL Date/Time 类型

    2024-05-13 09:21:22
  • 运用mysqldump 工具时需要注意的问题

    2024-01-20 07:11:56
  • 兼容所有浏览器的CSS3圆角[译]

    2009-10-13 21:11:00
  • Python中的Classes和Metaclasses详解

    2022-07-08 09:28:47
  • asp之家 网络编程 m.aspxhome.com