Vue.js 还是 React?你会选择哪一个?为什么?

简介:

两者之间的区别很有意思,但不仅仅局限于 JSX 与 Templates 或者丰富的 API 与少量的 API 的区别。React 和 Vue 两者之间的选择可能导致截然不同的结果,这一点在你一开始选择的时候可能并没有意识到。当选择一个框架的时候,一个重要的问题是「我希望项目的复杂性在哪个部分」。

React 和 Vue 可以完成很多相同的东西,但它们的实现方式截然不同。从一些反馈来看,我很好奇是否有人真的同时使用这两个框架来做一些东西,而不是写一些简单的组件,只有那样才能透过表面肤浅的差异,真正了解两者之间的内在区别。

不知你是否知道,Vue 深化了单文件组件的思想。一个文件由模版、脚本、样式,这些相互独立的模块组成。有人发现这种方式开发起来很舒服,因为每个模块的开发和传统的前端开发流程相似。我个人很喜欢这种模块,不是因为它「长得像 html」,而是它就像页面上的地标一样,层次分明,容易识别,通过地标就能很快地寻找到文件本身。React 中 JS 和 JSX 的组合运行得很好,但还是有点混乱(特别是当你添加样式组件到组合中去的时候)。而你无视这些,并习惯它了。有必要指出的是:React 使用 SFC(无状态组件)时需要一个编译步骤,但 Vue 不需要。正因为 JSX 需要一个编译步骤,所以当你考虑用 React 时你要多加考虑。如果你想要在不需要编译的前提下把几个 script 文件合并到一个项目中,那么 React 真的不是一个很好地选择,除非你打算放弃 JSX 改用 React.createElement()。这种情况下,Vue 是显而易见更好的选择。

关于 Vue 的其他评论是:它使用了 DSL(领域专用语言) 并且有大量的 API。两者都是真的,至少它的 API 比 React 要多,但相对于其他的库来说,它还是算少的。这两个情况是分离但相关的。Vue 使用的 DSL 只是另一个抽象概念,就像 SFC 一样。它们被设计出来是为了你能更加高产,并使你的代码保持整洁,表述清晰。JXS 的存在是同样的原因,它也是非标准化抽象,但是允许你发挥 JavaScript 全部的能量。JSX 不是 JavaScript,并且永远不会是,比如说 airbnb 的代码风格指南禁止在 .js 文件中包含 JSX,因为它们是非标准化的。它们必须在自己的 .jsx 文件中运行。

一旦你知道 Vue 的 DSL 包含了一系列辅助方法和简写来让你更高效,那要不要选择它就看你个人喜好了。换句话说(译者注:如果选择 Vue)你有更多的特殊语法要学。有的人讨论学习新的 API 会带来认知上的负担,这个质疑是有必要的(虽然我存有异议),但是我会和他们争论:正因如此,反过来说,简单的 API 意味着我们需要使用相对复杂的模式去完成特定的内容,React 因此也给我们带来大量认知负担。我会解释这个。~我们不要忘记 React 的 API 数量在不断增加,并以合理的速度持续增加。我们最近获得了 context API,在将来的某个时间点,我们还将获得 Time Slicing 和 Suspense。~ 另外要注意到,React 同样被驱动着更新。React 团队很在意用户的需要,并且在他们觉得有意义的地方做出改变。Context、Time Slicing、Suspense 这些特性已经或者即将被添加。尽管这样,React API 仍然可能保持简洁而且只有当有意义的时候,特性才会被添加。

值得一提的是,Vue 的文档是 API 文档的典范,它极其简洁。React 文档在平均水平,也还可以,它的 API 更简单所以按道理说你不需要过多地查阅文档。这一评论已经被批评了,但我坚持这一点,因为其他文档太糟糕了,也没让 React 文档看上去很好,相对于 Vue,它们确实很一般。我不是说 React 的文档特别糟糕,只是相对于你所期待的优秀的库而言,它很一般。

下面让我们来讨论抽象。所有的前端框架都在做抽象,有的抽象到更高的层级,有的更低。使用纯 JS 以声明式的风格来写 UI 组件是极其困难的,所以 React 和 Vue 提供了很多方法来做到这一点,并带上许多有用的插件,允许我们绑定状态到 DOM,而无需存储状态到 DOM,以及在内容变化时可以高效地渲染。

所有的这些意味着,如果你不想,你不必使用 Vue 的模板和 DSL。你可以只使用 React 中的 JSX 或者 createElement() 函数。你也可以自己选择模板语言,比如 Pug。不知你有没发现,Vue 在这方面非常灵活。它能够使用 SFC 来写真正的 UI 组件,只用 JS 来写非渲染组件(只输出 script 代码块,不包括 template 和 style),然后根据你的需要切换到 JSX 或者渲染函数。这种方法会给予你对工作方式难以置信的控制力,并让你的代码保持整洁。

当你开始写更加高级的组件或者想要写真正的可复用组件(特别是那种包装其他组件为它赋能的组件),你会开始发现一些明显的区别。使用 React,你需要使用一个或多个高阶组件,render props 或者函数作为子组件的开发模式。这些模式没有任何问题,对于现实问题它们是很好地解决方式,但它们增加了明显的认知困难(比学习新的语法更加多),因为它们真的是很复杂的模式。使用 Vue,这些模式没有必要,因为它有更多的 API,暴露了一系列传递数据的方法(如果你有兴趣的话了解一下嵌套插槽)。这意味着在 Vue 中,你可以使用上面那些模式,也可以使用其他形式的模式(嵌套插槽类似于 render props)。

这不是说 Vue 比 React 简单,也不是说 React 特别让人疑惑(嵌套插槽至少和 render props/ FaCC 一样复杂)。很多人忽略的关键点是使用 React 你需要尽快学会这些模式(很多流行的库使用它们),但是 Vue 中的嵌套插槽使用得不是很频繁。这一点有很多理由,再次说明,重要的区别不在于这些框架各自能做些什么,而是解决普通问题使用到复杂模式的频率。

它们都是拥有各自优点的强大框架,任何你可以使用一个做到的事,另一个也可以(真的很多)。React 拥有更大的生态系统以及更好的工具,拥有更多的工作机会。Vue 更容易上手,拥有出色的灵活性,它的 API 能让你避免使用 React 中的一些复杂模式,它以一种更符合语言习惯的 'Vue' 的方式运行。比如向父组件传递消息,而不是将回调函数作为属性向下传递。它能让你的代码更整洁,但这也是额外的抽象。Vue 还有更多核心库,和 Vue 紧密结合在一起,它们运行的方式和其他框架的类似方法基本相同。React 拥有的核心库少一些(Vue的一些标准函数到了 React 就需要引一个库,比如检查 prop 类型),但总体上拥有的库却更多(由社区提供)。值得牢记的是,随着生态圈的发展,你最终能得到大量做相同事情的库,我在 React 或者 Vue 中使用的大多数库抛开样式写法基本上和你选用的框架(React 还是 Vue)无关(React 会让你重新思考样式布局,这不是一件坏事),所以你达成目标需要做的事可能会发生变化。在我看来,一个强大的生态系统的最终影响是,你面临的问题很可能别人已经解决了,这是 React 的流行带来的巨大红利,,也是重要的考虑因素。

我两个都使用,也都很喜欢。它们用不同的方式让我困惑。它们都有各自的特性你需要去习惯。如果我不得不选择一个?我会选择 Vue。但这并不意味着你应该选。亲自去试试,看看你感觉怎么样。对于任何严厉的批评或者过高的赞许都要保持怀疑态度,因为它们都是由真正聪明的人开发的优秀框架,你选择任何一个都不会太差。我已经试着保持中立,给出重要的区别。我可能已经失败了,因为有些东西在一个框架让人很恼火,而另一个框架不会。

作者按:我忘了提到 vue-cli,它类似于 create-react-app+。这真的是一个非常棒的工具,能够快速建立可视化 UI,这一点很有趣。所以从某种意义上来说,Vue 中的工具真的很棒。我同样忘了提 Typescript 在 Vue 中的整合目前还不是很好,可能在 React 中会有更好的 TS 体验。值得继续深究。

去尝试吧。


作者:allenWang
链接:https://juejin.im/post/5b25b3a16fb9a00e70686180
来源:掘金
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。
相关文章
|
21天前
|
开发框架 前端开发 JavaScript
React、Vue.js 和 Angular主流前端框架和选择指南
在当今的前端开发领域,选择合适的框架对于项目的成功至关重要。本文将介绍几个主流的前端框架——React、Vue.js 和 Angular,探讨它们各自的特点、开发场景、优缺点,并提供选择框架的建议。
32 6
|
1月前
|
前端开发 JavaScript 开发者
React 和 Vue.js 框架的区别是什么?
React 和 Vue.js 框架的区别是什么?
|
1月前
|
前端开发 JavaScript API
React、Vue.js 和 Angular前端三大框架对比与选择
前端框架是用于构建用户界面的工具和库,它提供组件化结构、数据绑定、路由管理和状态管理等功能,帮助开发者高效地创建和维护 web 应用的前端部分。常见的前端框架如 React、Vue.js 和 Angular,能够提高开发效率并促进团队协作。
52 4
|
1月前
|
前端开发 JavaScript 开发者
Express.js与前端框架的集成:React、Vue和Angular的示例与技巧
本文介绍了如何将简洁灵活的Node.js后端框架Express.js与三大流行前端框架——React、Vue及Angular进行集成,以提升开发效率与代码可维护性。文中提供了详细的示例代码和实用技巧,展示了如何利用Express.js处理路由和静态文件服务,同时在React、Vue和Angular中构建用户界面,帮助开发者快速掌握前后端分离的开发方法,实现高效、灵活的Web应用构建。
44 3
|
2月前
|
前端开发 JavaScript API
构建高效Web应用:React与Node.js的完美结合
【8月更文挑战第29天】在当今快速变化的软件开发领域,构建高性能、可扩展的Web应用成为开发者的首要任务。本文将深入探讨如何利用React和Node.js这两大技术栈,打造一个高效且响应迅速的现代Web应用。从前端的用户界面设计到后端的服务逻辑处理,我们将一步步分析这两种技术如何协同工作,提升应用性能,并确保用户体验的流畅性。通过实际代码示例和架构设计的解析,本篇文章旨在为读者提供一套清晰的指南,帮助他们在项目开发中做出更明智的技术选择。
|
2月前
|
前端开发 Java UED
JSF 面向组件开发究竟藏着何种奥秘?带你探寻可复用 UI 组件设计的神秘之路
【8月更文挑战第31天】在现代软件开发中,高效与可维护性至关重要。JavaServer Faces(JSF)框架通过其面向组件的开发模式,提供了构建复杂用户界面的强大工具,特别适用于设计可复用的 UI 组件。通过合理设计组件的功能与外观,可以显著提高开发效率并降低维护成本。本文以一个具体的 `MessageComponent` 示例展示了如何创建可复用的 JSF 组件,并介绍了如何在 JSF 页面中使用这些组件。结合其他技术如 PrimeFaces 和 Bootstrap,可以进一步丰富组件库,提升用户体验。
48 0
|
2月前
|
前端开发 JavaScript 开发者
【前端革新力】React与CSS-in-JS完美邂逅:从styled-components到emotion,全面解析样式管理新趋势的实战应用与优势剖析!
【8月更文挑战第31天】CSS-in-JS 作为一种新兴的样式管理方式,近年来在前端社区受到广泛关注。它将样式嵌入 JavaScript,实现了样式与逻辑的高度耦合,提升了开发效率并解决了全局样式污染等问题。本文通过具体代码示例,探讨 CSS-in-JS 在 React 开发中的应用,并分享实践心得。首先介绍了 CSS-in-JS 的基本概念,然后详细展示了如何使用 styled-components 和 emotion 这两个流行库创建样式化组件。
87 0
|
2天前
|
缓存 JavaScript 前端开发
《基础篇第4章:vue2基础》:使用vue脚手架创建项目
《基础篇第4章:vue2基础》:使用vue脚手架创建项目
13 3
|
5天前
|
JavaScript 前端开发 开发者
Vue v-for 进阶指南:in 与 of 的区别及应用场景 | 笔记
Vue.js 中的 v-for 是强大的遍历指令,但其中的 in 和 of 关键字往往被开发者忽视。尽管它们的用法相似,但适用的场景和数据结构却各有不同。本文将详细探讨 v-for 中 in 和 of 的区别、适用场景以及在实际开发中的最佳使用时机。通过理解它们的差异,你将能够编写更加高效、简洁的 Vue.js 代码,灵活应对各种数据结构的遍历需求。
40 6
|
2天前
|
缓存 JavaScript
Vue 中 computed 与 method 的区别
【10月更文挑战第15天】computed 和 method 是 Vue 中两个重要的选项,它们在功能和特点上存在着明显的区别。理解并合理运用它们的区别,可以帮助我们构建更高效、更具可维护性的 Vue 应用。在实际开发中,要根据具体情况灵活选择使用,以满足不同的需求。
5 2