携手创作,共同成长!这是我参与「掘金日新计划 · 8 月更文挑战」的第 18 天,点击查看活动详情

前端框架经历了十多年的争奇斗艳百花齐放,经历了 JSP、jQuery、Ember、Angular、React、Vue、Solid、Svelte 等等。如今所有人都要承认的一个事实是:在上百个前端框架中,最具影响力的只剩下了两个,Vue 与 React。
Vue 进入 3.x 时代已经将近 2 年了,React 也在今年 3 月 29 日发布了 React 18 版本。
今天就来聊聊在当今 2022 年,两者还有哪些区别。
下面我们从头开始对比它们,看看到底谁更胜一筹。

安装与启动

从两个框架的安装开始。

Vue

Vue 提供了 Vue CLI 创建 Vue 项目,安装命令如下:

npm install -g @vue/cli
复制代码

安装成功后可以通过查看版本来确定安装成功。

vue --version
复制代码

创建新的项目运行以下命令:

vue create project
cd project
npm run serve
复制代码

React

创建 React 项目的工具是 create-react-app,简称 CRA。

npm install -g create-react-app
复制代码

创建新的项目运行以下命令:

npx create-react-app project
cd project
npm run start
复制代码

结论

两者在安装和启动项目上几乎一致,平手。

Props

两个框架都是使用组件作为基础开发的,那么父子组件传值就成了一个问题。props 是将数据从父组件传递给子组件的关键技术。

Vue

在 Vue 中,props 使用普通的字符串传递。也可以通过 v-bind 指令传递变量,缩写是冒号(:)。
父组件传值:

<template>
<Modal :isOpen="open" title="创建项目" />
</template>
复制代码

子组件访问 props 需要使用 defineProps 函数:

<template>
<form v-if="isOpen">
<p>{{ title }} </p>
</form>
</template> <script setup>
const props = defineProps({
isOpen: Boolean,
title: String
});
</script>
复制代码

React

在 React 中,props 是通过花括号传递变量的。
父组件传值:

<Modal isOpen={open} title="创建项目" />
复制代码

子组件通过参数的方式获取 props:

function Modal({ isOpen, title }) {
return (
{isOpen &&
<form>
<p>{ title }</p>
</form>
);
}
复制代码

结论

在传递 props 时,Vue 需要在属性前面额外添加指令,如果忘记添加指令会导致传递字符串。React 则不会有这种情况。
在子组件取值时,Vue 需要调用 defineProps 函数,React 通过函数的参数获取,更加自然。
综合对比,Vue 心智负担更大,React 则更加自然。这一轮 React 胜。

Event

Vue 使用了模板语法,React 使用了 JSX 语法。所以在编写 HTML 上发生了变化。但我们仍然需要为元素添加鼠标事件、键盘事件等。事件的处理也是一个必须事情。

Vue

Vue 处理事件通过 v-on 指令完成的,简写是 AT 符号(@)。

<template>
<button @click="displayName"> Show Name </button>
<template> <script setup>
function displayName() {
// TODO
}
</script>
复制代码

React

React 创建事件的方式和原生 HTML 几乎一致,区别是将绑定事件的属性名要求为驼峰命名法。

function NameAlert() {
const displayName = () => {
// TODO
}
return (
<button onClick="displayName"> Show Name </button>
);
}
复制代码

结论

React 更加自然,Vue 仍然是需要额外的操作符,如果忘记添加操作符,就会变成传递字符串的 props,React 则没有这个问题。这一轮 React 胜。

State

两者都是数据驱动的响应式框架,那么管理状态就成了一个关键问题。

Vue

在 Vue 中,通过 ref 或者 reactive 来创建状态。
两者的用法稍有不同,ref 是用来处理基础类型的状态的,而 reactive 通常处理引用类型的状态。
使用 ref 状态时需要通过 ref.value 来访问状态。

<template>
<div>
<p>{{ firstname }}</p>
<p>{{ lastname }}</p>
</div>
</template> <script setup>
import { ref, reactive } from 'vue'; const firstname = ref('张');
console.log(firstname.value); const lastname = reactive('三');
console.log(lastname);
</script>
复制代码

监听某个状态变化的方法是 watch 和 watchEffect。
两者的区别是 watchEffect 会在最初运行一次。

import { watch, watchEffect } from 'vue';

watch(firstname, () => alert('firstname 改变了!');

watchEffect(lastname, () => alert('lastname 改变了!');
复制代码

React

React 使用 useState 来创建状态。

import { useState } from 'react';

function ShowName() {
const [firstName, setFirstName] = useState('张');
const [lastName, setLastName] = useState('三'); console.log(firstName, lastName); return (
<div>
<p>{ firstname }</p>
<p>{ lastname }</p>
</div>
)
}
复制代码

React 使用 useEffect Hook 来监听状态变化。这个 Hook 接受一个回调函数和一个依赖数组。当依赖数组中任意一个状态发生变化时,回调函数就会触发。

import { useEffect } from 'React';

useEffect(() => {
console.log('名字改变了!');
}, [firstName, lastName]);
复制代码

结论

Vue 在创建状态和监听状态时分别提供了多种方式,我们在使用时需要考虑哪种情况该用哪种 API,而 React 分别只提供了一种方式,但是它同样可以做到应对各种情况。综合对比,Vue 心智负担更高,React 更简单。这一轮 React 胜。

Ref

尽管两门框架都使用组件进行编程,但我们还是难免需要访问 DOM,比如添加动画、控制输入框焦点等。为了解决这类问题,两门框架都提供了 ref 的概念,使用它可以创建对 DOM 的引用。

Vue

Vue 提供了 ref API。

<template>
<div>
<input type="text" ref="name" />
<button @click="handleBtnClick"> 开始输入 </button>
</div>
</template> <script setup>
import { ref } from 'vue'; const name = ref(null); handleBtnClick(() => {
name.value.focus();
}
</script>
复制代码

React

React 提供了 useRef Hook。但是要访问 DOM,需要使用 ref.current 属性。

import { useRef } from 'react';

function MyName() {
const name = useRef(null); handleBtnClick(() => {
name.current.focus();
}); return (
<input type="text" ref="name" />
<button onClick={handleBtnClick}> 开始输入 </button>
)
}
复制代码

结论

几乎没什么区别,平。

双向数据绑定

我们在使用 input、select、textarea 这类元素的时候,输入的值需要和状态进行同步。而状态发生变化时,元素的值也应该被同步。这个功能被称作数据双向绑定。

Vue

Vue 提供了 v-model 指令创建双向绑定。

<template>
<input v-model="searchQuery" />
</template> <script setup>
import { ref } from 'vue'; const searchQuery = ref('');
</script>
复制代码

React

React 没有为这项功能单独提供 API,但我们也可以实现。

import { useState } from 'react';

function MyComponent() {
[searchQuery, setSearchQuery] = useState(''); const handleChange = (event) => {
setSearchQuery(event.target.value);
} return (
<input value={searchQuery} onChange={handleChange}/>
);
}
复制代码

结论

从语法上看,Vue 更简洁。但是这会破坏单向数据流的原则,因为改变数据的方式不再是只有一种。React 的代码虽然不简洁,但更加容易追踪状态。这也是 React 和 Vue 在设计理念上的不同。在「让开发者写更少的代码」和「代码结构更加清晰易于维护」之间,Vue 选择了前者,React 选择了后者。至于谁好谁坏,个人更加倾向于后者,但是也有人倾向于前者。因为是取舍问题,平。

动态渲染

有些时候我们的组件是根据某些条件进行渲染的,这也就是动态渲染。

Vue

Vue 提供了三个指令:v-if、v-else 和 v-show。

<template>
<div>
<p v-if="isLoggedIn"> 欢迎 </p>
<p v-else> 请登录 </p>
<button v-show="!isLoggedIn">登陆</button>
</div>
</template>
复制代码

React

React 没有为这种功能提供任何 API,而是使用原生 JavaScript 的条件语句,if、&& 或者是三元运算符等。

function MyComponent() {
return (
{isLoggedIn ?
<p>欢迎</p> :
<p> 请登录 </p>
}
{!isLoggedIn && <button> 登陆 </button>}
);
}
复制代码

结论

Vue 的语法是在元素上添加特殊的属性,而 React 的语法是纯粹的 JavaScript 语法。从语法上看,没有太大差别。但是 Vue 会有额外的学习成本。综合来看,这轮 React 略胜一筹。

渲染子组件

有时我们需要在组件中将子组件传递给其他组件一起渲染。

Vue

Vue 提供了 slot 来传递子组件。
容器组件:

<template>
<div>
<h1>Welcome</h1>
<slot><slot>
</div>
</template>
复制代码

父组件:

<template>
<div>
<h1>欢迎来到我的网站</h1>
<Modal>
<input type="text" />
<button>登陆</button>
</Modal>
</div>
</template>
复制代码

React

React 的子组件是一个 props 上面的一个属性:children。
容器组件:

function Modal( {children} ) {
return (
<div>
<h1>Welcome</h1>
{ children }
</div>
);
}
复制代码

父组件:

function UserPage() {
return (
<div>
<h1>欢迎来到我的网站</h1>
<Modal>
<input type="text" />
<button>登陆</button>
</Modal>
</div>
);
}
复制代码

结论

从上面的例子中看不出两者太大的差距。但是在更复杂的情况下,比如要传递 N 个子组件。React 可以通过属性进行传递,操作组件就和操作变量一样;Vue 则有了命名插槽、插槽动态名称、范围插槽等概念,操作起来比较麻烦,而且心智负担也高。这一轮 React 胜。

总结

通过本文,我对比了两个框架中大部分的概念和语法,各自有各自的优势,很难说清楚到底谁更好。
早在 2016 年左右我第一次对两者做对比的时候,感觉差距还是蛮大的,那时候 React 还是 class 组件的时代,还要靠 this.setState 来更新状态,组件也拥有很多复杂的生命周期。Vue 还是 Options API 的时代,也不怎么好用,比如 this 的问题;data 必须传递函数再返回一个对象;所有东西都要定义,使用组件要定义,使用事件要定义......
再来看今天的 React 和 Vue,似乎都在向同一个方向房展,而且越来越像。
虽然有相互借鉴的成分存在,但是从几年前就一直有一个质疑的声音,说 Vue 抄袭 React。特别是 Vue3 推出了 Composition API 之后,越来越像 React。甚至于有人说 Vue3 的代号海贼王,就是暗喻自己是从 React 那里偷走了很多东西。
你认为呢?

总结给大家推荐一个实用面试题库

 1、前端面试题库 (面试必备)            推荐:★★★★★

地址:前端面试题库

2、前端技术导航大全      推荐:★★★★★

地址:前端技术导航大全

3、开发者颜色值转换工具   推荐:★★★★★

地址 :开发者颜色值转换工具

前端框架大比拼:2022年的Vue与React谁更胜一筹?的更多相关文章

  1. 4.VUE前端框架学习记录四:Vue组件化编码2

    VUE前端框架学习记录四:Vue组件化编码2文字信息没办法描述清楚,主要看编码Demo里面,有附带完整的代码下载地址,有需要的同学到脑图里面自取.脑图地址http://naotu.baidu.com/ ...

  2. 3.VUE前端框架学习记录三:Vue组件化编码1

    VUE前端框架学习记录三:Vue组件化编码1文字信息没办法描述清楚,主要看编码Demo里面,有附带完整的代码下载地址,有需要的同学到脑图里面自取.脑图地址http://naotu.baidu.com/ ...

  3. 前端框架之争丨除了Vue、Angular和React还有谁与之争锋

    转载请注明出处:葡萄城官网,葡萄城为开发者提供专业的开发工具.解决方案和服务,赋能开发者. 原文参考:https://www.sitepoint.com/most-popular-frontend-f ...

  4. 前端框架本质之探究——以Vue.js为例

    问:我们在使用Vue时,实际上干了什么?   答:实际上只干了一件事——new了一个Vue对象.后面的事,都交由这个对象自动去做.就好像按了下开关,机器跑起来了,剩下的事就不用我们再操心了.   各位 ...

  5. 2.VUE前端框架学习记录二

    VUE前端框架学习记录二:Vue核心基础2(完结)文字信息没办法描述清楚,主要看编码实战里面,有附带有一个完整可用的Html页面,有需要的同学到脑图里面自取.脑图地址http://naotu.baid ...

  6. Vue.js教程 1.前端框架学习介绍

    Vue.js教程 1.前端框架学习介绍 什么是Vue.js 为什么要学习流行框架 什么是Vue.js Vue.js 是目前最火的一个前端框架,React是最流行的一个前端框架(React除了开发网站, ...

  7. React 还是 Vue: 你应该选择哪一个Web前端框架?

    学还是要学的,用的多了,也就有更多的认识了,开发中遇到选择的时候也就简单起来了. 本文作者也做了总结: 如果你喜欢用(或希望能够用)模板搭建应用,请使用Vue    如果你喜欢简单和“能用就行”的东西 ...

  8. 前端框架对比之vue与regular(一)

    每次一写到Regular总是忍不住先介绍一下,Regualr是网易杭州研究所的一位叫郑海波的大神写的一款前端框架,目前 这款框架推广的不深,加上其和angular过于相似的框架名,导致接受力并不大,其 ...

  9. 一款简单而不失强大的前端框架——【Vue.js的详细入门教程①】

    ↓— Vue.js框架魅力 —↓ 前言       Vue.js 是一个构建数据驱动的 web 界面的渐进式框架.Vue.js 的目标是通过尽可能简单的 API 实现响应的数据绑定和组合的视图组件.V ...

  10. 前端框架:react还是vue?

    之前写了一篇前端框架的大汇总,主要介绍了当下主流的框架和其特性.最近除了bootstrap,就属react和vue最为热门,这篇就主要拿这两个框架来做一下详细对比. 究竟如何正确使用?作为小白的我们从 ...

随机推荐

  1. 【FAQ】推送服务常见问题及解决方案

    一.推送成功收不到消息,推送返回:{"message":"success","requestID":"1523868*****28 ...

  2. 【Redis实战专题】「性能监控系列」全方位探索Redis的性能监控以及优化指南

    Redis基本简介 Redis是一个开源(BSD 许可).内存存储的数据结构服务器,可用作数据库,高速缓存和消息队列代理.它支持字符串.哈希表.列表.集合.有序集合等数据类型.内置复制.Lua 脚本. ...

  3. (12)go-micro微服务JWT跨域认证

    目录 一 JWT介绍 二 JWT优缺点 三 JWT使用 1. 导包和数据定义 2.生成JWT 3.解析JWT 4.完整代码 四 最后 一 JWT介绍 JWT 英文名是 Json Web Token , ...

  4. AIGC 很火,想微调个自己的模型试试看?(不是卖课的)

    去年,我们发布过一篇关于 DreamBooth 编程马拉松的活动通知,获得了全球社区的广泛关注和参与,中国社区的成员们也对这个活动有非常高的热情.同时我们也收到了后台留言反馈说参与活动需要使用的 Go ...

  5. 如何进行动态ip的域名解析设置?

    如何进行动态ip的域名解析设置?目前,有一部分域名客户出于节省成本.技术验证等因素,会把自己家里或是部门的电脑用来当做Web服务器.mail服务器或是ftp服务器.如果想提供给其他人长期浏览,一般都要 ...

  6. css边框,盒子模型、浮动、定位

    边框,盒子模型.浮动.定位 一.边框 border-width : 边框宽度 border-style : 边框样式 1.solid 实线 2.none 无边框 3.dotted 点状虚线边框 4.d ...

  7. 前端知识点(js部分)

    目录 一.JS简介 简介 ECMAScript的历史 二.JS基础 1.注释语法 2.引入js的多种方式 3.结束符号 三.变量与常量 编写和运行js代码的两种方式 变量声明 四.基本数据类型 1.数 ...

  8. python学习第七周总结

    C/S模块 1C/S模块: 1.1Client:客户端:客户端也就是你这一端可以接收到的程序,手机app,web网页等,我们可以在客户端页面上向度武器发送请求以及数据,交给服务器处理. 1.2Serv ...

  9. echarts入门到应用学习笔记

    背景: 做疫情数据管理可视化,需要用到热点图在web端进行数据可视化,而地图就是必不可少的一个,看完文档,可以解决大部分小白的问题,保姆级攻略,即使你的js,这些学得不咋样(我就是小菜鸟) 步骤 环境 ...

  10. Kinsoku jikou desu新浪股票接口变动

    1.问题原因 新浪股票接口返回如标题所示值:Kinsoku jikou desu! http://hq.sinajs.cn/list=code 新浪股票的接口变动,需要在请求头中添加Referer值. ...