漫谈前端:2025年框架是该选vue还是react?

news/2024/9/30 14:19:14 标签: 前端框架, vue.js, react.js

相信很多前端小伙伴都有过纠结的时候,开始一个项目的时候是该选vue还是react。很多情况下,都是根据团队现有框架延续,或者是自身数量度。渐渐的公司组件和规范全基于某一种框架,虽然很爽但Allin难掉头。本文就浅浅的比较下vue和react框架,谈一谈个人看法。

目前二者的版本和周下载对比:

名称最新版本周下载(百万次)问题数
vue3.5.105.5642
react18.3.125.8650

 比较可惜的是目前npmjs官网差不多vue2的数据了,react的全球下载量是react的五分之一,而国内npmmirror下载量每周也就0.5m,react稍微小一点0.4m左右。二者都比年初要提升不少,只是vue基数比较小,总体来看vue的用户数量是比react少一些的。但国内react用户量在增加明显

下面将对比下二者使用上的差异,设计和性能就不比较了,其实都差别不太大。

1. 状态管理

Vue 3

在 Vue 3 中,setup 是一个新引入的生命周期钩子,它允许我们通过 refreactive 创建和管理组件内部的状态。setup 函数的主要优点是更容易组织和复用逻辑,尤其是与组合式 API 搭配使用时。

<template>
  <div>
    <p>{{ count }}</p>
    <button @click="increment">Increment</button>
  </div>
</template>

<script >
import { ref } from 'vue';

export default {
  setup() {
    const count = ref(0);
    
    const increment = () => {
      count.value++;
    };

    return { count, increment };
  }
};
</script>

在这个示例中,ref 用于声明响应式状态 count,并且 setup 函数返回的数据会暴露给模板。

React (函数式组件)

React 中,状态管理依赖于 useState 钩子。React 的函数式组件(FC)是无状态的,但通过 Hooks(如 useStateuseReducer)可以实现状态管理。
j

import React, { useState } from 'react';

const Counter = () => {
  const [count, setCount] = useState(0);

  const increment = () => {
    setCount(count + 1);
  };

  return (
    <div>
      <p>{count}</p>
      <button onClick={increment}>Increment</button>
    </div>
  );
};

export default Counter;

在这个示例中,useState 钩子用于创建和管理 count 的状态,并通过回调函数 setCount 更新状态。

对比

特性Vue 3 (setup)React FC (useState)
状态声明使用 refreactive使用 useState
响应式处理Vue 内置响应式系统React 使用 Hooks,非响应式
逻辑组织组合 API 更易复用逻辑Hooks 使逻辑复用变得灵活
语法复杂度较为简洁,ref.value 语法相对简洁

2. 数据流

Vue 3

在 Vue 3 中,数据流主要通过 props 向下传递,emits 向上传递。父子组件间的数据流较为明确,借助 setup 函数可以简化状态和逻辑处理。

// Parent.vue
<template>
  <Child :message="parentMessage" @reply="handleReply" />
</template>

<script>
import Child from './Child.vue';

export default {
  components: { Child },
  setup() {
    const parentMessage = ref('Hello from Parent');
    const handleReply = (replyMessage) => {
      console.log(replyMessage);
    };

    return { parentMessage, handleReply };
  }
};
</script>

React (函数式组件)

在 React 中,数据流也通过 props 传递,父组件可以通过回调函数接收子组件传递回来的数据。

// Parent.js
import React from 'react';
import Child from './Child';

const Parent = () => {
  const parentMessage = 'Hello from Parent';

  const handleReply = (replyMessage) => {
    console.log(replyMessage);
  };

  return <Child message={parentMessage} onReply={handleReply} />;
};

export default Parent;

React 和 Vue 都遵循自顶向下的数据流,但 React 的 props 是单向绑定,Vue 则支持更灵活的双向绑定机制(例如 v-model)。

对比

特性Vue 3 (setup)React FC
数据传递props 向下,emits 向上props 向下,回调向上传递
数据流模式支持单向/双向数据绑定主要是单向数据流
事件处理使用 emits$emit使用回调函数传递事件

3. Provide/Inject(依赖注入)

Vue 3

Vue 3 提供了 provideinject 来实现祖先组件与后代组件之间的通信,允许在组件树中上下层级之间传递数据,而不必通过 props 层层传递。provideinjectsetup 中使用时更加简洁和直观。

 

// Parent.vue
<template>
  <Child />
</template>

<script>
import { provide, ref } from 'vue';
import Child from './Child.vue';

export default {
  components: { Child },
  setup() {
    const message = ref('Hello from Parent');
    provide('parentMessage', message);
  }
};
</script>

// Child.vue
<template>
  <p>{{ parentMessage }}</p>
</template>

<script>
import { inject } from 'vue';

export default {
  setup() {
    const parentMessage = inject('parentMessage');
    return { parentMessage };
  }
};
</script>

React (Context API)

React 中没有直接的 provide/inject,但是通过 Context API 实现类似功能。Context 允许在组件树中向下传递数据,无需通过每一级组件手动传递 props

 

import React, { createContext, useContext, useState } from 'react';

const MessageContext = createContext();

const Parent = () => {
  const [message] = useState('Hello from Parent');

  return (
    <MessageContext.Provider value={message}>
      <Child />
    </MessageContext.Provider>
  );
};

const Child = () => {
  const message = useContext(MessageContext);
  return <p>{message}</p>;
};

export default Parent;

对比

特性Vue 3 (provide/inject)React (Context API)
用途祖先与后代组件之间的数据传递全局或层级深的状态共享
语法复杂度相对简单,内置 API相对复杂,需要 Context 和 Hooks
使用场景轻量级依赖注入状态、主题、配置等全局数据

4. 组件管理

Vue 3 (setup)

Vue 3 通过 setup 更容易将逻辑拆分到多个文件或组合函数中,逻辑复用也更灵活。在 Vue 3 中,组合式 API 提供了一种清晰的方式来管理组件的生命周期和逻辑。

示例:通过组合函数(useCounter)将逻辑抽离出来:

// useCounter.js
import { ref } from 'vue';

export function useCounter() {
  const count = ref(0);
  const increment = () => {
    count.value++;
  };
  
  return { count, increment };
}

// Counter.vue
<template>
  <div>
    <p>{{ count }}</p>
    <button @click="increment">Increment</button>
  </div>
</template>

<script>
import { useCounter } from './useCounter';

export default {
  setup() {
    const { count, increment } = useCounter();
    return { count, increment };
  }
};
</script>

React (函数式组件)

React 使用 Hooks 进行逻辑复用和组件管理,通过自定义 Hooks 可以将组件的逻辑抽离和复用。

示例

// useCounter.js
import { useState } from 'react';

export const useCounter = () => {
  const [count, setCount] = useState(0);

  const increment = () => {
    setCount(count + 1);
  };

  return { count, increment };
};

// Counter.js
import React from 'react';
import { useCounter } from './useCounter';

const Counter = () => {
  const { count, increment } = useCounter();

  return (
    <div>
      <p>{count}</p>
      <button onClick={increment}>Increment</button>
    </div>
  );
};

export default Counter;

对比

特性Vue 3 (setup)React FC (Hooks)
逻辑复用组合 API(自定义组合函数)自定义 Hooks
代码可读性逻辑集中,提升可读性Hooks 易于拆分和管理
生命周期管理提供组合 API,直观通过 Hooks 处理(如 useEffect

5 总结

特性Vue 3 (setup)React FC
状态管理refreactive 提供响应式状态useState 提供非响应式状态
数据流propsemits 实现单向/双向流props 和回调函数实现单向流
依赖注入内置依赖注入,适合祖孙组件通信使用 Context API 实现全局状态
组件管理和逻辑复用组合 API 更灵活且可读性强Hooks 易于拆分逻辑,但有时复杂

选型建议

  • Vue 3 更适合那些希望简化组件逻辑和状态管理的开发者,特别适用于中小型项目或希望以更加响应式的方式管理状态的场景。但并不是说vue3无法开发大型项目。
  • React 更适合大型项目,特别是具有复杂交互逻辑、需要深度拆分逻辑和复用组件的场景。(目前vue3的jsx还是有些gap的,后续章节我会说明下)React 的生态系统广泛,适合团队协作和长期维护
  • 国内政企项目推荐vue3,毕竟有点优势,vue2也够用,但上2.7版本得谨慎。
  • 个人项目随意,建议交叉混用,以便训练思维,如果比较急就挑顺手的吧
  • 对外项目,比如跨境、港澳合作以及面向国外团队,选择react会有优势,毕竟react的外部生态更庞大,又有大公司背书,这个主要是一信任度的问题,尤其是fb的开源做的真不差

最后,通过二者兼修(甚至多修svelte-angular等),尝试找到适合自己的开发模式,找到合适的状态管理(我选了rxjs作为中间层),剥离出UI和状态,后续我会介绍一些实践经验。


http://www.niftyadmin.cn/n/5685293.html

相关文章

2024必读NLP书籍!《自然语言处理:基于预训练模型的方法》附PDF!

自然语言处理被誉为“人工智能皇冠上的明珠”。深度学习等技术的引入为自然语言处理技术带来了一场革命&#xff0c;尤其是近年来出现的基于预训练模型的方法&#xff0c;已成为研究自然语言处理的新范式。而今天给大家推荐的这本《自然语言处理&#xff1a;基于预训练模型的方…

高级java每日一道面试题-2024年9月26日-运维篇[分布式篇]-如何保证每个服务器的时间都是同步的?

如果有遗漏,评论区告诉我进行补充 面试官: 如何保证每个服务器的时间都是同步的? 我回答: 确保服务器之间的时间同步对于维护分布式系统的一致性、日志记录的准确性以及安全认证的有效性非常重要。以下是几种常见的方法来保证服务器时间同步&#xff1a; 1. 使用NTP&#…

星辰计划5-深入解析源码(逐行debug)dubbo服务引用,调用

dubbo服务引用 ReferenceConfig的创建初始化之路 构造函数 发现并没有啥特别的 public ReferenceConfig() {super();this.repository ApplicationModel.getServiceRepository(); }但是发现这个实例初始化的时候需要构造这些静态属性对象 协议集群(这个没用上不知道为啥不去…

【ESP 保姆级教程】小课设篇 —— 案例:20231223_基于UNO RFID的公交卡设计

忘记过去,超越自己 ❤️ 博客主页 单片机菜鸟哥,一个野生非专业硬件IOT爱好者 ❤️❤️ 本篇创建记录 2024-09-30 ❤️❤️ 本篇更新记录 2023-09-30 ❤️🎉 欢迎关注 🔎点赞 👍收藏 ⭐️留言📝🙏 此博客均由博主单独编写,不存在任何商业团队运营,如发现错误,请…

[Cocoa]_[初级]_[使用NSNotificationCenter作为目标观察者实现时需要注意的事项]

场景 在开发Cocoa程序时&#xff0c;由于界面是用Objective-C写的。无法使用C的目标观察者[1]类。如果是使用第二种方案2[2],那么也需要增加一个代理类。那么有没有更省事的办法&#xff1f; 说明 开发界面的时候&#xff0c;经常是需要在子界面里传递数据给主界面&#xff0…

ACM第三次考核题解

ACM第三次考核题解 题目序号难度题目编号题目考察知识点1签到题A这是一道很难的题&#xff01;&#xff01;&#xff01;输出2迷之难度F神说要有光&#xff0c;于是有了手电筒贪心3简单BThis is a real English problem&#xff01;思维 英语4简单C玩具简单排序5简单I“近义词…

自然语言处理实战项目:从基础到实战

自然语言处理实战项目&#xff1a;从基础到实战 自然语言处理&#xff08;Natural Language Processing, NLP&#xff09;是人工智能的重要分支&#xff0c;致力于让计算机能够理解、生成和处理人类语言。NLP 在搜索引擎、智能客服、语音助手等场景中扮演着关键角色。本文将带…

Qt网络编程——QUdpSocket

文章目录 Qt网络编程QUdpSocketUdp回显服务器Udp客户端 Qt网络编程 网络编程本质上是写应用层代码&#xff0c;需要传输层提供支持。 而传输层最核心的协议就是UDP和TCP&#xff0c;这两个协议有较大差别&#xff0c;所以Qt提供了两套API。 要是有Qt网络编程的API&#xff0…