Vue3是一个错误,我们不应该再犯

2022-11-26 0 888

文档是译者的,作者Fotis Adamakis, 他是 Vue.js斯巴达会议的共同发起者,该文的第三人称指的是该元老。

从起初导入Vue 3已经开始,早已过去了4年多。经过多次RFC的讨论,以及其他现代构架(主要包括React和Svelte)的影响,Vue 可能将早已正式成为最强悍和最全面的构架,能够逐步全力支持任何规模和构架的应用。

听起来很刺激,对吗?嗯,历史事实绝非如此。从那以后,就发生了很多延后和降班的情况。尽管Vue 3最近正式成为了捷伊预设版,但很多关键的全力支持库还没准备好,甚至没计划与两个版相容。这说明很多标识符库还逗留在Vue 2上,北迁到版3的方向并不难。

请不要误会我,Vue 3非常棒。它可能将是目前最好的构架了。但历史事实上,从第二版已经开始没简单的北迁方向,这是两个严重错误,他们不如果在未来多次重复。

Vue 2的难题

Vue一直被认为是两个不断进步的构架。快捷键API很难理解,他们能学习并在需要时导入更复杂的模式和库。小的TypeScript和良好的文件格式是大家喜欢它的原因。

另一各方面,在将通用型方法论抽象化为mixin时,采用承继而不是女团的数据库系统瑕疵造成了很多可扩展性难题,并破坏了整洁模块新闻稿的很多原则。Vue3 导入组合API 作为一种软件系统。

另两个关键的难题是对typecript的全力支持。当然,在Vue模块中撰写typescript就像在script条码中加进type=”ts”一样难。但在模版和 store 里,全力支持是有难题的。

vue3 软件系统

完全改写是两个明显改善构架在结构上的机会。Vue3 广泛地采用了Typescript,主要包括积极响应性机制在内的很多各方面都Cubzac。这使得Vue 3在报文大小、如上所述图形、更新和缓存采用各方面的操控性得到了明显的明显改善。

此外,还增加了很多捷伊机能。

Composition API句法糖 <script setup>FragmentsEmits Component Option来自@vue/runtime-core的createRenderer API能建立自订图形库style 里面能存取表达式SFC的<style scoped>现在能主要包括自上而下准则或只针对连接埠内容的准则Suspense

新机能明显改善了整体的合作开发新体验,热烈欢迎很多合作开发都的青睐。争辩的关注点是,其中大部分机能,主要包括女团API、teleport、 suspense 等,在Vue 2中早已都能用了,所以它们不能真正算是构架的改良。

真正的难题

破坏的性变化,有很多。其中一些很简单,比如Events API。Vue实例不能再用作事件总线,但有即插即用的软件系统,如 mitt 或 tiny-emitter,能用作直接替代。这需要有一定工作时间,但能及时完成,没太多风险。

另一各方面,有些变化不能安全地进行,也不能不进行小规模或大规模的重构。在两个用Vue 2构建的现有大型应用中,你可能将会采用一些被废弃或改变的API。

北迁构建如果是两个版之间的桥梁,但由于有这么多被废弃的机能,它对大型项目并不适用。此外,官方对一些基本的全力支持库的建议是北迁到另两个不同的库,这进一步增加了复杂性。由于有这么多的移动模块,即使北迁构建成功,也需要大量的工作,这对大项目来需要有更多的时间用来解决技术债务。

Vue3是一个错误,我们不应该再犯

不需要的东西

Vue始终是两个有意义的构架。你能试着猜测两个API如果如何工作,你很可能将是对的。Vue 3不再是这种情况。

两个例子是关于捷伊基于函数的Vue模块撰写方式的意见征集,有大量的回应,主要包括正面和负面的。不管你在这场争辩中的立场如何,将社区分成两半绝不是两个好兆头。

文件格式

在合作开发过程中,特别是在两个捷伊构架中,谷歌和StackOverflow是你最好的朋友。目前,Vue 2的答案占据了压倒性的优势,但在Vue 3中,很多API实现的原理都不一样了,因此可能将会造成一定的混乱。

生态

两个构架有多强悍,它的生态系统就有多强悍。有争议的决定和不负责任的废弃机能驱使很多贡献者离开,导致很多库被放弃。但是,当你没给开源库两个可行的方法来全力支持两个版的时候,就指责他们没跟上你的版时,这表明你缺乏同情心和对大局的理解。

两个构架的真正力量来自于它周围的社区和生态系统。

过去

如果你有幸在2015年前后写标识符,你有可能将会采用当时最主流的构架AngularJS。

转到 Vue 3的看起来很像从 AngularJS 到 Angular(版1⇒2)的过渡。大量的破坏性的变化导致了挫败感,最终Angular失去了对React和Vue的吸引力。

如果你是两个全栈工程师,你可能将熟悉大约10年前在Python生态系统中发生的同样情况。在大约十年的时间里,很多项目无法升级,因为很多核心库没增加对Python 3的全力支持,而出现的新库只全力支持Python 3。当然,后来的Python版已经开始只在版3上加进捷伊和闪亮的机能,这种混乱的情况还没真正结束。

未来–这种情况会再次发生吗?

看起来前进的方向是向后退,把所有的东西都移植到北迁构建中,但是损害早已造成了,合作开发满意度看起来并不乐观,不能忽视。有远见地让构架参与进来是合理的,但合作开发经验是构架的核心职责之一。Vue 4如果考虑到整个生态系统,并提供两个北迁方向,否则它将正式成为没人愿意采用的最佳构架。

到目前为止,你对Vue 3的北迁有什么经验?请在评论中分享你的想法和建议。

编辑中可能将存在的bug没法实时知道,事后为了解决这些bug,花了大量的时间进行log 调试,这边顺便给大家推荐两个好用的BUG监控工具 Fundebug。

原文:https://fadamais.medium.com/vue-3-was-a-mitake-that-we-should-not-repeat-81cc65484954

相关文章

发表评论
暂无评论
官方客服团队

为您解决烦忧 - 24小时在线 专业服务