react好还是vuejs好 如何设置前端ios设置自动弹起键盘

签箌排名:今日本吧第个签到

本吧因你更精彩,明天继续来努力!

成为超级会员使用一键签到

成为超级会员,赠送8张补签卡

点击日历上漏签日期即可进行补签

超级会员单次开通12个月以上赠送连续签到卡3张

该楼层疑似违规已被系统折叠 


扫二维码下载贴吧客户端

两者之间的区别很有意思但不僅仅局限于 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 体验。值得继续深究

著作权归作者所有。商业转载请联系作者获得授权非商業转载请注明出处。

我要回帖

更多关于 vue.js是什么 的文章

 

随机推荐