React 的学习记录一:与 Vue 的相同点和区别

目录

一、学习目标

二、学习内容1️⃣——React的特点

1.组件化设计

2.单向数据流

3.声明式 UI

4.虚拟 DOM

5.Hooks

6.JSX 

7.React Native

三、React与vue的比较总结

四、总结


一、学习目标

时间:两周

内容:

  • React的特点
  • React的入门
  • React的功能、API
  • 深入了解 Hook
  • 学习路由和状态管理
  • React的原理等等

二、学习内容1️⃣——React的特点

这里主要是记录React的特点,中间会查询很多内容,在此记录总结一下,其中会涉及很多与vue的相同点和不同点比较,很多都是个人理解总结,所以不具备广泛的定义(不要当成文档来学习哦!记岔劈了我不负责)。

1.组件化设计

React 采用组件化的设计理念,UI 被拆分为独立的、可复用的组件。每个组件负责自己的一部分 UI,并且可以互相组合形成复杂的界面。

文档里这样描述组件:

React有两种类型的组件:函数组件、类组件,使用JSX语法能将HTML、JavaScript混在一起

相比之下,Vue 的组件化思想体现在将组件作为界面构建的基本单元,比如常见的单页面(.vue文件)就是一个组件,里面有三个部分,模板(HTML)、脚本(JavaScript)、样式(CSS)等部分。

因为都是组件化设计的思想,就都有一个特点:可复用、数据驱动UI(view)、并且都有生命周期方法/钩子。

不同点:React 组件必须以大写字母开头,而 HTML 标签则必须是小写字母。而vue就没有这个限制,但也推荐这种写法。

2.单向数据流

Vue 和 React都使用单向数据流(One-Way Data Binding),即数据从父组件传递到子组件(vue的props),而子组件只能通过回调函数(比如vue的emit通)知父组件数据的变化。

这种单向流动有助于数据的可预测性,使应用的数据流向更清晰,尤其在大型应用中便于维护和调试,也更可追溯,更可控状态变更的源头也更唯一

但是vue有双向绑定,在表单的输入时通过v-model可以自动同步数据和状态,是一种单向数据流的补充,而react就是手动设置来控制表单数据的双向绑定。

 确实,react的单向数据流需要手动控制可以避免一些隐式转换的变化,还有vue的响应式的一些坑。

3.声明式 UI

这个的意思是:开发者只需定义组件的最终状态,框架会根据数据的变化和状态的更新,自动处理 DOM 操作来实现这些效果。

也可以理解为vue的MVVM设计架构里的VM这种思路(我vue学的多,就用这个来指代了),当数据发生变化时,框架会自动计算并更新所需的 DOM 节点,而开发者不需要直接访问或操作 DOM 元素。

除了声明式UI还有一种叫做传统的命令式UI,就需要手动操作DOM,比如使用 jQuery 手动更新 DOM 的方式。

所以,这两个框架在这种情况下,都会监听界面里的数据的变化,并自动更新视图,也就是开发者只需要描述 UI 应该如何显示,而不必手动操作 DOM。

优势嘛,也就是:减少代码复杂度、提高代码可维护性等等,也更简单了吧。

4.虚拟 DOM

虚拟dom这个概念,这个东西的产生是为了提高性能和效率,避免频繁地操作真实DOM,提到这个就会提到一个不可绕开的东西——diff算法。

这里主要对两个框架生成和更新虚拟dom的过程进行对比:

React 和 Vue 虚拟 DOM 的区别
特性ReactVue
更新机制深度对比(diffing algorithm——最小化差异算法,会尽可能多地对比所有的虚拟 DOM 节点),逐层比较基于响应式系统和依赖追踪,异步更新队列(通过 nextTick 来更新),并且按需更新,diff才用双端比较策略
虚拟 DOM 生成每次重新生成新的虚拟 DOM基于响应式数据自动生成和更新虚拟 DOM
性能优化应用批量更新,即多个状态更新操作会合并到一次更新中,减少重复渲染精细化的响应式数据跟踪,减少不必要的组件更新
组件更新组件的更新需要通过 shouldComponentUpdateReact.memo 优化通过依赖追踪和异步更新,自动优化渲染
虚拟 DOM 更新的方式每次对比新旧虚拟 DOM,寻找最小差异只更新受影响的部分,减少不必要的 DOM 操作
响应式系统无内建响应式系统,需要借助 useState 等 Hook 来管理状态内建响应式系统,自动跟踪依赖并更新

当然这里提及一个vue2,vue3的diff算法的区别,因为我是vue较熟练,所以对这个进行了总结:

  • Vue 2

    • 基于双端比较策略。
    • 使用完整的虚拟 DOM 树和 key 来标记节点。
  • Vue 3

    • 对静态节点进行优化:通过静态节点标记,跳过不需要 Diff 的部分,提高性能。
    • 更加高效的 PatchFlag 机制:用于标记节点变化类型,减少不必要的对比。
    • 支持 Fragment 和 Teleport 等特性。

本来想写一篇diff的相关知识,但是看了几篇发现有很不错的,就不费力去写了, 推荐这篇:

vue3手写diff算法(图解+例子+详细注释) 

写的很棒,还解释了v-for的时候key的原理,在源码中一闪而过,但是我并没有仔细去了解的。

5.Hooks

Hooks就是钩子,可以理解为特定时机会触发的东西,vue3因为组合式API的出现,就提出新的逻辑复用的方案——hooks(也被称之为vue hooks,与react做区分),都是为了更好地组织逻辑、复用功能、提升代码可维护性而设计的。当然两者的实现方式和使用场景有一定区别。

因为这个很重要,所以对两个的代码进行比较:

React Hooks:

import { useState, useEffect } from "react";function useCounter(initialValue) {const [count, setCount] = useState(initialValue);useEffect(() => {console.log(`Count updated: ${count}`);}, [count]);return { count, increase: () => setCount(count + 1) };
}// 使用
function Counter() {const { count, increase } = useCounter(0);return (<div><p>Count: {count}</p><button onClick={increase}>Increase</button></div>);
}

Vue Composition API:

import { ref, watch } from "vue";function useCounter(initialValue) {const count = ref(initialValue);watch(count, (newCount) => {console.log(`Count updated: ${newCount}`);});const increase = () => {count.value++;};return { count, increase };
}// 使用
setup() {const { count, increase } = useCounter(0);return { count, increase };
}

 关于两者的对比:

React 和 Vue 关于Hook 的区别
特性ReactVue
逻辑复用自定义Hooks,返回状态和方法,更加轻量,适合纯逻辑处理,通过函数封装独立函数或者模块,内置响应式和依赖追踪,适合复杂业务的逻辑独立
生命周期useEffect模拟组件的生命周期onMounted,onUnmounted等都有
状态管理useState:不可变值的状态更新ref,reative,基于proxy的响应式系统
计算属性无,手动实现computed
副作用处理使用useEffect,依赖数组控制执行watch、watchEffect
复杂场景需要多个Hooks配合使用,状态管理需要引入Redux等易于处理状态关联的复杂场景,因为有响应式

 总结:

  • React Hooks 偏向于函数式编程,更加轻量,但需要开发者对依赖和状态管理有良好掌控能力。
  • Vue Composition API 内置响应式系统,逻辑清晰且高度灵活,适合复杂项目

6.JSX 

JSXJavaScript XML 的缩写,它是一种语法糖,可以在 JavaScript 中直接编写类似 HTML 的代码,浏览器无法直接运行 JSX,必须通过 Babel 等工具编译成标准的 JavaScript。它是 React 社区设计和推广的,React 对 JSX 提供了强大的支持。

React的官方教程里就有对JSX的规则介绍:

JSX 规则

JSX有一些特点,比如被大家熟知的:多个 JSX 标签需要被一个父元素包裹、使用驼峰式命名法等等。

Vue 默认使用模板语法,但支持 JSX,需额外安装 Babel 插件。

7.React Native

这里我了解太少,暂时只是将概念特性整理下来了:

  • 跨平台

    • 使用一套代码,同时运行在 iOS 和 Android 上。
    • 支持大部分原生组件和 API。
  • 性能接近原生

    • 使用 JavaScript 与设备原生模块交互,通过 Native Bridge 实现性能接近原生的应用。
  • 热更新与开发效率高

    • 支持 Hot ReloadingFast Refresh,在不重启应用的情况下,立即查看代码更改的效果。
    • 可通过 OTA(Over-The-Air)技术实现热更新,无需重新发布到应用商店。
  • 社区支持强

    • React Native 社区非常活跃,提供了大量的第三方库,极大地减少了开发时间。
  • 组件化开发

    • RN 的 UI 是基于组件的,这与 React 的开发理念一致,能够轻松实现代码复用。

三、React与vue的比较总结

对上面提到的几点特效进行总结,以下:

React与Vue的特点比较
相同点不同点:React不同点:Vue
1.组件化设计都是组件构成、可复用、数据驱动UI(view)、并且都有生命周期方法/钩子

组件的定义:函数组件、类组件JSX语法;

命名:React 组件必须以大写字母开头而 HTML 标签则必须是小写字母

组件的定义:一个单文件(.vue);

三个部分混在一起;

命名:不强制要求

2.单向数据流都遵循强调数据状态的可追溯、更严格

强调响应式;双向绑定

3.声明式 UI都遵循
4.虚拟 DOM都有更新机制、重新生成、批量更新、更新方式、没有响应式更新机制、自动生成、按需更新、有响应式和依赖追踪
5.Hooks都有,但是表现形式不一致生命周期是useEffect实现的,需要多个Hooks配合使用,状态管理需要引入Redux等生命周期有,易于处理状态关联的复杂场景,因为有响应式
6.JSX有,特定的规则没有,只是有模板语言
7.React Native跨平台、性能接近原生

对上面提到的几点特效进行总结,以下

四、总结

以上,暂时是这些,未完~学习过程中会持续更新!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/888193.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

深度学习-52-AI应用实战之基于Yolo8的目标检测自动标注

文章目录 1 YOLOv81.1 YOLOV8的不同版本1.2 可检测类别1.3 数据说明1.4 网络结构1.5 算法核心步骤2 目标检测的基本原理2.1 安装yolov8(cpu版本)2.2 图片检测2.3 视频检测2.4 自动标注2.5 保存标注结果3 参考附录1 YOLOv8 YOLOv8是一种前沿的计算机视觉技术,它基于先前YOLO版…

数据库管理-第267期 23ai:Oracle Data Redaction演示(20241128)

数据库管理267期 2024-11-286 数据库管理-第267期 23ai&#xff1a;Oracle Data Redaction演示&#xff08;20241128&#xff09;1 示例表及数据2 创建编校策略2.1 名字全编校2.2 电话部分编校 3 DML演示3.1 场景13.2 场景2 总结 数据库管理-第267期 23ai&#xff1a;Oracle Da…

hue 4.11容器化部署,已结合Hive与Hadoop

配合《Hue 部署过程中的报错处理》食用更佳 官方配置说明页面&#xff1a; https://docs.gethue.com/administrator/configuration/connectors/ 官方配置hue.ini页面 https://github.com/cloudera/hue/blob/master/desktop/conf.dist/hue.ini docker部署 注意&#xff1a; …

Vue 3 中实现页面特定功能控制

在开发 Vue 应用时&#xff0c;我们经常会遇到需要在特定页面启用或禁用某些功能的情况。本文将以 A父.vue 页面为例&#xff0c;探讨如何在点击汇总菜单时仅在该页面生效&#xff0c;而在其他页面不生效的问题。 1. 利用 Vue 3 的 provide 和 inject 实现状态传递 Vue 3 提供…

Spring Boot自定义启动banner

在启动 Springboot 应用时&#xff0c;默认情况下会在控制台打印出 Springboot 相关的banner信息。 自定义banner 如果你想自定义一个独特的启动banner&#xff0c;该怎么做呢&#xff1f;Springboot 允许我们通过自定义启动banner来替换默认的banner。只需要在 resources 目…

leaflet 的基础使用

目录 一、创建dom节点 二、创建地图 三、添加底图&#xff08;天地图&#xff09;&#xff0c;在地图创建完成后添加底图 本章主要讲述leaflet在vue中的使用&#xff1a; leaflet 详情总目录&#xff1a;传送 一、创建dom节点 <div class"map" id"map_…

C++分治思想

分治思想的定义 分治思想是C中很重要的一个思想&#xff0c;它的主旨是“将大的问题化作小的问题&#xff0c;将小问题在化作更小的问题”。就是这样一个看起来十分简单的思想&#xff0c;却涵盖了许许多多的算法&#xff0c;如递归&#xff0c;递推&#xff0c;贪心等。 分治…

ubuntu的用户使用

ubuntu系统中的常规用户登录方式 在系统root用户是无法直接登录的,因为root用户的权限过大所以其安全性比较差 在登录系统时一般使用在安装系统时建立的普通用户登录 如果需要超级用户权限: Ubuntu用户密码破解 在系统安装完成后默认grub启动等待时间为0&#xff0c;建议改…

浏览器拨测:将网站护航的阵地再前推一米

作者&#xff1a;泉思 “从你在地址栏里敲下回车开始到你在网页上看到内容中间经过了哪些步骤”&#xff0c; 这是一个非常常见的互联网公司的面试题。想必很多开发者对于这个问题可以给出一个非常完整的回答&#xff0c;但是对于用户来说&#xff0c;在网页上看到内容仅仅是服…

Modern Effective C++ 条款二十七:熟悉通用引用重载的替代方法

item26中说明对使用通用引用形参的函数&#xff0c;无论是独立函数还是成员函数&#xff0c;进行重载都会导致一系列问题。但是也提供了一些示例&#xff0c;如果能够按照我们期望的方式运行&#xff0c;重载可能也是有用的。这个条款探讨了几种通过避免在通用引用上重载的设计…

【RL Application】语义分割中的强化学习方法

&#x1f4e2;本篇文章是博主强化学习&#xff08;RL&#xff09;领域学习时&#xff0c;用于个人学习、研究或者欣赏使用&#xff0c;并基于博主对相关等领域的一些理解而记录的学习摘录和笔记&#xff0c;若有不当和侵权之处&#xff0c;指出后将会立即改正&#xff0c;还望谅…

【C++】优先队列(Priority Queue)全知道

亲爱的读者朋友们&#x1f603;&#xff0c;此文开启知识盛宴与思想碰撞&#x1f389;。 快来参与讨论&#x1f4ac;&#xff0c;点赞&#x1f44d;、收藏⭐、分享&#x1f4e4;&#xff0c;共创活力社区。 目录 一、前言 二、优先队列&#xff08;Priority Queue&#xff09…

【SQL】实战--组合两个表

题目描述 表: Person ---------------------- | 列名 | 类型 | ---------------------- | PersonId | int | | FirstName | varchar | | LastName | varchar | ---------------------- personId 是该表的主键&#xff08;具有唯一值的列&#xff09;…

STL:相同Size大小的vector和list哪个占用空间多?

在C中&#xff0c;vector和list是两种不同的序列容器。vector底层是连续的内存&#xff0c;而list是非连续的&#xff0c;分散存储的。因此&#xff0c;vector占用的空间更多&#xff0c;因为它需要为存储的元素分配连续的内存空间。 具体占用多少空间&#xff0c;取决于它们分…

《Serverless 架构:引领未来软件开发的新趋势》

一、引言 随着云计算技术的不断发展&#xff0c;软件开发模式也在不断演进。Serverless 架构作为一种新兴的云计算架构模式&#xff0c;正在逐渐改变着软件开发的方式和流程。本文将深入探讨 Serverless 架构的概念、特点、应用场景以及未来发展趋势。 二、Serverless 架构概述…

Java的关键字和保留字

理解什么是关键字&#xff1f; Java赋予了某些单词特殊意义&#xff0c;就不能自己在代码中起同名一样的&#xff0c;否则提示错误 【在Java中关键字都是小写的&#xff0c;并不是所有的小写字母都是关键字&#xff0c;一般在IDEA中显示高亮橘黄色】 理解什么是保留字&#xf…

三十二:HTTP 协议的基本认证

在 Web 开发中&#xff0c;HTTP 协议提供了一种简单的方式来进行身份验证&#xff0c;即 基本认证&#xff08;Basic Authentication&#xff09;。这种认证方式广泛应用于需要保护的资源或 API 接口&#xff0c;它通过在 HTTP 请求头中传递用户名和密码来验证用户身份。虽然基…

GPT vs Claude到底如何选?

美国当地时间6月20日&#xff0c;OpenAI的“劲敌”Anthropic公司发布了最新模型Claude 3.5 Sonnet。据Anthropic介绍&#xff0c;该模型是Claude 3.5系列模型中的首个版本&#xff0c;也是Anthropic迄今为止发布的“最强大、最智能”的模型。它不仅在性能上超越了竞争对手和自家…

Ubuntu 22.04 LTS vs Ubuntu 24.04 LTS:深度剖析,哪个版本更胜一筹?

在开源操作系统领域&#xff0c;Ubuntu一直以其稳定、易用和丰富的功能而受到广泛好评。随着Ubuntu 24的发布&#xff0c;许多用户开始关注这两个版本之间的差异&#xff0c;并考虑是否应该升级到最新版本。鼎峰新匯Benson将对比Ubuntu 22和Ubuntu 24&#xff0c;以帮助用户做出…

Ubuntu 22.04 离线安装软件包

在使用最小化安装时&#xff0c;默认是不带有vim 或者nano编辑器的&#xff0c;如果你的环境不能上外网就需要离线安装。 首先你需要先找一台可以上网的ubuntu系统&#xff08;虚拟机搭建也行&#xff09;&#xff0c;下载所有的依赖包&#xff0c;然后上传到需要安装的服务器…