2025年前端框架是该选vue还是react?有了大模型-例如通义灵码辅助编码,就不用纠结了!vue用的多选react,react用的多选vue

本文涉及的产品
视觉智能开放平台,视频资源包5000点
视觉智能开放平台,分割抠图1万点
NLP自然语言处理_基础版,每接口每天50万次
简介: 本文比较了Vue和React两大前端框架,从状态管理、数据流、依赖注入、组件管理等方面进行了详细对比。当前版本和下载量数据显示React更为流行,但Vue在国内用户量增长迅速。Vue 3通过组合式API提供了更灵活的状态管理和组件逻辑复用,适合中小型项目;React则更适合大型项目和复杂交互逻辑。文章还给出了选型建议,强调了多框架学习的重要性,认为技术问题已不再是选型的关键,熟悉各框架的最佳实践更为重要。

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

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

名称 最新版本 周下载(百万次) 问题数
vue 3.5.10 5.5 642
react 18.3.1 25.8 650

比较可惜的是目前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>

image.gif

在这个示例中,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;

image.gif

在这个示例中,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>

image.gif

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;

image.gif

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>

image.gif

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;

image.gif

对比

特性 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>

image.gif

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;

image.gif

对比

特性 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和状态,后续我会介绍一些实践经验。


有了大模型帮助,技术问题不再是选型关键


均衡的练习,熟悉更多框架才是需要做的,很多时候你不需要动手写代码,写好需求+代码生成即可!更重要的是能够看得懂各个框架的代码,熟悉各个框架的最佳实践!


至于API啊语法啊,相信我,通义灵码比任何人都熟练,实在没记住的,把整个文档页面下载然后丢给它就行啦!


所以选一样用的少的,来见识点多样性吧~找到更好的最好,找不到会让你更热爱现在所用的技术!

相关文章
|
21天前
|
前端开发 JavaScript 开发者
颠覆传统:React框架如何引领前端开发的革命性变革
【10月更文挑战第32天】本文以问答形式探讨了React框架的特性和应用。React是一款由Facebook推出的JavaScript库,以其虚拟DOM机制和组件化设计,成为构建高性能单页面应用的理想选择。文章介绍了如何开始一个React项目、组件化思想的体现、性能优化方法、表单处理及路由实现等内容,帮助开发者更好地理解和使用React。
55 9
|
26天前
|
前端开发 JavaScript Android开发
前端框架趋势:React Native在跨平台开发中的优势与挑战
【10月更文挑战第27天】React Native 是跨平台开发领域的佼佼者,凭借其独特的跨平台能力和高效的开发体验,成为许多开发者的首选。本文探讨了 React Native 的优势与挑战,包括跨平台开发能力、原生组件渲染、性能优化及调试复杂性等问题,并通过代码示例展示了其实际应用。
53 2
|
28天前
|
前端开发 JavaScript 开发者
React与Vue:前端框架的巅峰对决与选择策略
【10月更文挑战第23天】React与Vue:前端框架的巅峰对决与选择策略
|
28天前
|
前端开发 JavaScript 开发者
“揭秘React Hooks的神秘面纱:如何掌握这些改变游戏规则的超能力以打造无敌前端应用”
【10月更文挑战第25天】React Hooks 自 2018 年推出以来,已成为 React 功能组件的重要组成部分。本文全面解析了 React Hooks 的核心概念,包括 `useState` 和 `useEffect` 的使用方法,并提供了最佳实践,如避免过度使用 Hooks、保持 Hooks 调用顺序一致、使用 `useReducer` 管理复杂状态逻辑、自定义 Hooks 封装复用逻辑等,帮助开发者更高效地使用 Hooks,构建健壮且易于维护的 React 应用。
32 2
|
28天前
|
前端开发 JavaScript 数据管理
React与Vue:两大前端框架的较量与选择策略
【10月更文挑战第23天】React与Vue:两大前端框架的较量与选择策略
|
2月前
|
JavaScript 前端开发 算法
前端优化之超大数组更新:深入分析Vue/React/Svelte的更新渲染策略
本文对比了 Vue、React 和 Svelte 在数组渲染方面的实现方式和优缺点,探讨了它们与直接操作 DOM 的差异及 Web Components 的实现方式。Vue 通过响应式系统自动管理数据变化,React 利用虚拟 DOM 和 `diffing` 算法优化更新,Svelte 通过编译时优化提升性能。文章还介绍了数组更新的优化策略,如使用 `key`、分片渲染、虚拟滚动等,帮助开发者在处理大型数组时提升性能。总结指出,选择合适的框架应根据项目复杂度和性能需求来决定。
|
2月前
|
缓存 前端开发 JavaScript
前端serverless探索之组件单独部署时,利用rxjs实现业务状态与vue-react-angular等框架的响应式状态映射
本文深入探讨了如何将RxJS与Vue、React、Angular三大前端框架进行集成,通过抽象出辅助方法`useRx`和`pushPipe`,实现跨框架的状态管理。具体介绍了各框架的响应式机制,展示了如何将RxJS的Observable对象转化为框架的响应式数据,并通过示例代码演示了使用方法。此外,还讨论了全局状态源与WebComponent的部署优化,以及一些实践中的改进点。这些方法不仅简化了异步编程,还提升了代码的可读性和可维护性。
|
27天前
|
前端开发 Android开发 开发者
前端框架趋势:React Native在跨平台开发中的优势与挑战
【10月更文挑战第26天】近年来,React Native凭借其跨平台开发能力在移动应用开发领域迅速崛起。本文将探讨React Native的优势与挑战,并通过示例代码展示其应用实践。React Native允许开发者使用同一套代码库同时构建iOS和Android应用,提高开发效率,降低维护成本。它具备接近原生应用的性能和用户体验,但也面临平台差异、原生功能支持和第三方库兼容性等挑战。
32 0
|
28天前
|
前端开发 JavaScript 开发者
React与Vue:前端框架的巅峰对决与选择策略
【10月更文挑战第23天】 React与Vue:前端框架的巅峰对决与选择策略
|
2月前
|
缓存 前端开发 JavaScript
前端架构思考:代码复用带来的隐形耦合,可能让大模型造轮子是更好的选择-从 CDN 依赖包被删导致个站打不开到数年前因11 行代码导致上千项目崩溃谈谈npm黑洞 - 统计下你的项目有多少个依赖吧!
最近,我的个人网站因免费CDN上的Vue.js包路径变更导致无法访问,引发了我对前端依赖管理的深刻反思。文章探讨了NPM依赖陷阱、开源库所有权与维护压力、NPM生态问题,并提出减少不必要的依赖、重视模块设计等建议,以提升前端项目的稳定性和可控性。通过“left_pad”事件及个人经历,强调了依赖管理的重要性和让大模型代替人造轮子的潜在收益