译 | Vue.js:好的,”呵呵”的,不好的

从React迁移到Vue,使用两年后的感受总结。

使用新的框架和库总是会让人兴奋,但也有压力。即使经过一些测评,你也永远不知道以后会遇到什么意外发现。

我跟Vue.js的蜜月期结束了。在几乎每天使用Vue2年之后,我终于决定要写点关于它的事情了。

提示:下面内容纯属个人观点。

Vue.js的优秀部分

机动性

在前端世界,数据绑定是一件大事。我们不再像使用jQuery那样对DOM进行微观管理,而是关注数据。Vue使用双向反应数据绑定系统来处理这个问题。

为了实现这个能动性, Vue在状态(state)中的每个变量添加了一些getter和setter,以便它能够跟踪、更改,并自动更新DOM(咳咳this. setstate()咳咳)。这种方法并不完美,我们将在后面看到。

自己供电

使用Vue,不需要使用非正式的包,比如MobX或response Router来处理应用程序的关键部分。Vue提供Vue Router和Vuex——一个受redu启发的反应性中央状态管理器。它们本身就是很棒的库,但它们是为Vue定制的,这一点使它们变得更好。

速度

Vue真的是太快了。也许不是最快的,但它的性能对绝大多数web项目来说是顶级的。您上一次需要每秒呈现和更新数千个DOM元素是什么时候?

HTML模板

这在JavaScript开发人员中是一个有争议的话题。不管您喜欢什么,HTML模板已经在许多语言中进行了几十年的打磨,并且是在Vue中编写动态标记的首选。

而且,嘿,Vue也支持JSX。

其他的好东西

  • HTML、CSS和JavaScript单个文件组件。
  • 轻量。大约20KB(缩小+ gzip)。
  • 可扩展高(mixins、插件等)。
  • 优秀的文档(除了下面提到的一些例外)。
  • 可以渐进接入,甚至可以作为jQuery的替代品。
  • 容易上手。

Vue.js中让人“呵呵”的部分

组件模板

从React迁移到Vue,我似乎感受到一股清新的空气。不再到处bind(this) setState()。哎!但是在一段时间之后,我开始质疑Vue的组件语法的有效性。

Vue组件是用对象创建的,这里有一个定义组件函数的例子:

export default {
 methods: {
  increment () {
   this.count++;
  }
 }
}

您需要为计算属性、组件状态、监视程序等添加类似的模板文件。几乎所有Vue中的内容都有自己的特殊语法和更多的模板文件。

相比之下,Marko也有同样的事情,它更干净:

class {
 increment() {
  this.state.count++;
 }
}

我这里的重点不是使用类或不使用类,而是Vue使用任意的对象结构而不是语言特性。

如果你觉得我有点想找事,我不会怪你的。Vue还提供了基于类的语法,但它实际上更多的是事后考虑。

社区更像是个聊天室

Vue社区的人都喜欢使用一种叫Discord的工具闲聊。这是一种游戏社区里才会有的聊天工具。如果你遇到问题,聊天可能是你最好的选择,因为官方论坛是一片荒凉的土地,可为什么,你不敢在Github上问问题吗?

聊天很乱,主要的问题是聊天内容不能被搜索引擎索引。同样的问题(及其相关的讨论)注定要一遍又一遍地重复。

这种用聊天来提问的趋势正在困扰开源项目,我认为它需要停止。这种聊天里没有集体学习效果。

没有那么神奇

只要你不偏离正道,就不会遇到麻烦,但一段时间后,你可能会在Vue周围发现很多“如果”和“但是”。

一些例子:

  • reactivity系统只会在一定条件下跟踪变化。不要指望向它能提供任何你想要的东西。通常,您可能需要尽可能地简化数据,以避免头痛。当然,所有这些都在文档的小字中可以找到解释。
  • transition 系统<vue-transition>不适用于列表。您实际上需要使用<transitiongroup>,它的工作方式略有不同,而且会在DOM中引入新的元素。同样,有些东西你也会认为这是一件已经解决的事情,但你发现必须自己去实现它。
  • 如果您需要组件实例中的non-reactive状态,那么您将进入一个未知领域。
  • 等等。

别误会我的意思,这些都不是大问题,但似乎每次你开始动手的时候,另一个小烦恼就会冒出来。

Vue.js中不好的部分

不清晰架构模式

这里有一个例子:在组件中还是在Vuex中处理API请求更好?

该文档提供了如何处理Vuex中的API逻辑的示例。甚至还有一个漂亮的彩色图表:

这是否意味着验证逻辑也适用于Vuex ?状态管理器现在将开始做为所有应用程序逻辑的中介吗?

这些都不是显而易见的事情。大多数人喜欢将non-state逻辑插入到Vuex操作中,或者更糟的是,直接插入到组件中,因为Vue主页上有一段视频这样写道:

回答我最初的问题:API逻辑不应该放到Vuex或组件编写。在一些官方代码示例中,甚至还有一个很好的例子来说明如何做到这一点。

结论

Vue的使用率一直在不断增加,我怀疑这种趋势是否会很快停止。它的普及还远不及React(至少在中国以外),而且还在需要和Angular竞争遥远的第二名。

在过去,我认为Vue是一个实用的库,不同于React过于理想化的设计(“我们是纯JavaScript!”)。我仍然认为这是一个很好的比喻。另一方面,我现在觉得,Vue的实用主义需要在用户层面上更加优雅、专注、优雅和简洁。

在使用了2年后,我对Vue的印象是正面积极的。我仍然认为这是一个正确的决定——把我的团队从React带到Vue。不是因为Vue更好,而是因为它更适合我们。

Vue实现了它想做的目的,并且在其他人失败的领域取得了成功,但是,今天,我并不认为Vue客观上比你想象中的其他选择更好或更糟糕。

这些就是我要说的。

附录:Vue CLI

我没有在本文中包含Vue CLI,我想