Vue源码探究-构建版本的区别

栏目: 编程语言 · 发布时间: 4年前

内容简介:基于第三方性能评估工具Benchmark的测评结果可以看出Vue 2.0版本在整体的性能上得到了大幅优化,即使与React和Angular最新版相比也相差无几。在提供给使用者的构建版本方面,也进行了针对性的细化,输出了多种不同的版本,以便满足不同需求的开发者使用更精细更适合自己的版本。解释一下上表列出的所有版本的内容区别和使用场景,具体的术语就不一一解释了,英语可得靠自己好好学习:

基于第三方性能评估工具Benchmark的测评结果可以看出Vue 2.0版本在整体的性能上得到了大幅优化,即使与React和Angular最新版相比也相差无几。在提供给使用者的构建版本方面,也进行了针对性的细化,输出了多种不同的版本,以便满足不同需求的开发者使用更精细更适合自己的版本。

构建版本的比较

官方文档 上展示的概括图表(以下译自该文档):

UMD CommonJS ES Module
Full vue.js vue.common.js vue.esm.js
Runtime-only vue.runtime.js vue.runtime.common.js vue.runtime.esm.js
Full (production) vue.min.js
Runtime-only (production) vue.runtime.min.js

解释一下上表列出的所有版本的内容区别和使用场景,具体的术语就不一一解释了,英语可得靠自己好好学习:

vue.js

  • 内容:完整未压缩版,包括编译器和运行时两部分代码,支持通用模块引入和闭包返回Vue构造函数。
  • 建议使用场景:需要编译模板的开发环境。
  • 版本说明:由于未压缩,所以在生产环境下是不推荐使用的,这一版本比较适合学习源代码时使用。另外在Unpkg CDN上默认使用此完整版构建文件。

vue.min.js

  • 内容: 完整压缩版,内容和输出完全同上。
  • 建议使用场景:需要编译模板的生产环境、浏览器script标签直接引用。
  • 版本说明:在不想增加使用构建 工具 的学习曲线和复杂度时,直接使用script标签引入此版本可以无门槛直接进入Vue的学习和使用,并且支持通用模块加载。在生产环境建议使用压缩版可以减少30%的文件体积。

vue.common.js

  • 内容: 完整未压缩CommonJS版,内容同上,区别在于输出的是CommonJS模块。
  • 建议使用场景:需编译模板且使用老版本构建工具的开发环境。
  • 版本说明:由于此版本未压缩是不建议直接使用在生产环境上的。如果在使用构建工具的情况下可以直接使用对应的运行时版本,所以该版本的使用场景应该比较有限。

vue.esm.js

  • 内容: 完整未压缩ES Module版,内容同上,区别在于输出的是ES Module模块。
  • 建议使用场景:需编译模板且使用新版构建工具的开发环境。
  • 版本说明:同上。

vue.runtime.js

  • 内容: 未压缩运行时版,支持通用模块引入和闭包返回Vue构造函数。
  • 建议使用场景:不需要编译模板的开发环境。
  • 版本说明:这一版本也不建议在生产环境使用,需要模块加载可用相应的压缩版。

vue.runtime.min.js

  • 内容: 压缩运行时版,内容和输出完全同上。
  • 建议使用场景:不需要编译模板的生产环境。
  • 版本说明:如果不需要编译模板,可以使用这个版本,支持通用模块加载,也可以用script标签引入直接在浏览器中使用,是 体积最小的版本

vue.runtime.common.js

  • 内容: 未压缩版CommonJs构建版,内容同上,区别在于输出CommonJS模块。
  • 建议使用场景:不需编译模板且使用老版本构建工具时。
  • 版本说明:使用browserify或webpack1时默认使用该版本。

vue.runtime.esm.js

  • 内容: 未压缩版ES module构建版,内容同上,区别在于输出ES module模块。
  • 建议使用场景:不需编译模板且使用新版构建工具时.
  • 版本说明:使用webpack2和rollup时默认使用该版本, 在使用最新的vue-cli搭建的webpack脚手架时就是使用了这个版本

另外在仓库里发现的一个叫 vue.esm.browser.js 的文件,仔细看了一下与 vue.esm.js 相比用的全是ES6的语法,但图表里没有提到此文件是什么情况下使用,而且是稍前几次构建出的版本,个人猜想可能是没有什么特别的用处,只是没有删掉而已,欢迎指正。

完整版 vs. 运行时版

完整版的使用场景是需要即时编译模板的情况,什么是即时编译模板?

在程序运行中进行模板编译。这一过程如同动态加载,当把模板字符串作为配置选项的template属性传入Vue构造函数后再执行渲染进程;或使用DOM已有元素作为模板在运行时加载并编译,这些都是在运行中进行模板编译的实例。由此可见一般使用了 type="text/x-template"script 标签包含的模板就是在代码运行中进行加载编译的,所以此时需要完整版中的编译器来执行把模板转化成渲染函数的过程,否则通过vue进行构造的内容是无法显示的。在开发时如果使用了运行时版,Vue也会在 Console 中给出提示。

相反,如果使用构建工具开发,在程序运行之前就先执行了模板的编译过程, .vue 单文件组件会被编译转换成javascript代码,在浏览器中可以直接运行,所以此时只需使用运行时版本就可以支持Vue的正常运行,这样Vue的体积更小,有助于提升加载速度,所以在熟悉了Vue之后比较推荐配合使用构建工具来进行开发。

开发模式 vs. 生产模式

官方文档表示在通用模块版本中使用了开发和生产模式的硬编码,未压缩版的用于开发模式,压缩版的用于生产模式。

在使用构建工具时,建议使用与构建工具版本相应的未压缩版,这样在开发时参考错误信息报告和定位调试是非常便利的,而在构建打包到生产环境时,配套插件会负责压缩代码。

基于网页性能优化的原则,建议在生产环境中都要使用压缩版。只有在开发时才需要未压缩版中的错误提示信息方便定位错误及调整。

在2.0版本发布以后,Vue开始提供不同构建版本,大致了解之后发现在不同开发场景下选择适当的版本有助于减少开发时每次打包的速度,并且了解各种版本的不同后也能选择适合的生产版本提升应用的整体性能。在网上找了很久才发现原来官方Github上有比较详细的说明文档解释各种版本的区别,不过对于具体的使用场景没有特别突出的说明,最后还是自己花了些时间去比较和总结,算是又把心中的一块小石头给抹掉。我想对于目前跟我一样还不太了解Vue内部实现机制的同学来说,弄明白各种版本的差异是一个快速得到性能优化最佳实践的途径。


以上所述就是小编给大家介绍的《Vue源码探究-构建版本的区别》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

密码学概论(中文版)

密码学概论(中文版)

wade trappe、lawrence C.washington / 特拉普 / 人民邮电出版社 / 2004-6-1 / 38.00

本书全面讲解了密码学基本知识以及相关的基础数学理论,介绍了椭圆曲线、AES和量子密码体制等密码学前沿知识,详细地阐述了数字签名、数字现金等应用问题。另外,书中每章均给出了相应的习题,在附录中给出了相关Mathematica、Maple和 MATLAB实例。 本书可供高等院校就用数学、通信和计算机等专业用作密码学、通信安全和网络安全等课程的教材或参考书,也可供信息安全系统设计开发人......一起来看看 《密码学概论(中文版)》 这本书的介绍吧!

HTML 压缩/解压工具
HTML 压缩/解压工具

在线压缩/解压 HTML 代码

CSS 压缩/解压工具
CSS 压缩/解压工具

在线压缩/解压 CSS 代码

Base64 编码/解码
Base64 编码/解码

Base64 编码/解码