携手创作,共同成长!这是我参与「掘金日新计划 · 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. react 高效高质量搭建后台系统 系列 —— antd和样式

    其他章节请看: react 高效高质量搭建后台系统 系列 antd 后续要做登录模块(主页),不仅要解决请求数据的问题,还需要完成 antd 配置以及样式的准备. antd 多种主题风格 详情请看 这 ...

  2. 诗词API

    1.js依赖 /** * 今日诗词V2 JS-SDK 1.2.2 * 今日诗词API 是一个可以免费调用的诗词接口:https://www.jinrishici.com */ !function(e) ...

  3. ArcGIS工具 - 批量合并数据库

    在ArcGIS数据建库和入库过程中,经常需要将数据结构相同.数据内容不同的多个数据库文件进行合并,使用工具臬中复制.合并.追加都可以达到一定的效果,但都不能直接支持数据库的操作.当合并成百上千个数据库 ...

  4. 深入理解C++虚函数底层机制和RTTI运行时类型识别

    当调用一个虚函数时,被执行的代码必须与调用函数对象的动态类型相一致:指向对象的指针或引用的类型是不重要的,编译器是如何高效地提供这种行为呢?大多数编译器是使用virtual table和virtual ...

  5. API 网关的功能用途及实现方式

    1. API 网关诞生背景 前言 API 经济生态链已经在全球范围覆盖, 绝大多数企业都已经走在数字化转型的道路上,API 成为企业连接业务的核心载体, 并产生巨大的盈利空间.快速增长的 API 规模 ...

  6. 【Django drf】 序列化类常用字段类和字段参数 定制序列化字段的两种方式 关系表外键字段的反序列化保存 序列化类继承ModelSerializer 反序列化数据校验源码分析

    目录 序列化类常用字段类和字段参数 常用字段类 常用字段参数 选项参数 通用参数 序列化类高级用法之source source填写类中字段 source填写模型类中方法 source支持跨表查询 定制 ...

  7. JavaScript 评测代码运行速度

    一.使用 performance.now() API 在 JavaScript 中,可以使用 performance.now() API 来评测代码的运行速度.该 API 返回当前页面的高精度时间戳, ...

  8. vivo官网App模块化开发方案-ModularDevTool

    作者:vivo 互联网客户端团队- Wang Zhenyu 本文主要讲述了Android客户端模块化开发的痛点及解决方案,详细讲解了方案的实现思路和具体实现方法. 说明:本工具基于vivo互联网客户端 ...

  9. SQLSERVER 临时表和表变量到底有什么区别?

    一:背景 1. 讲故事 今天和大家聊一套面试中经常被问到的高频题,对,就是 临时表 和 表变量 这俩玩意,如果有朋友在面试中回答的不好,可以尝试看下这篇能不能帮你成功迈过. 二:到底有什么区别 1. ...

  10. YouCompleteMe用法总结

    1.将.ycm_extra_conf.py拷贝到工程目录,然后打开,将自己的include目录添加进去