最新公告
  • 欢迎您光临起源地模板网,本站秉承服务宗旨 履行“站长”责任,销售只是起点 服务永无止境!立即加入钻石VIP
  • Vite使Vue CLI过时了吗?

    正文概述 掘金(杭州程序员张张)   2020-12-18   476

    Vue生态系统中有一个名为Vite的新构建工具,它的开发服务器比Vue CLI快10-100倍。

    这是否意味着Vue CLI已经过时了?在本文中,我将比较这两种构建工具,并说明它们的优缺点,以便你可以决定哪一种适合你的下一个项目。

    Vue CLI概述

    大多数Vue开发人员都知道,Vue CLI是使用标准构建工具和最佳实践配置快速建立基于Vue的项目的不可或缺的工具。

    其主要功能包括:

    • 工程脚手架
    • 带热模块重载的开发服务器
    • 插件系统
    • 用户界面

    在本讨论中需要注意的是,Vue CLI是构建在Webpack之上的,因此开发服务器和构建功能和性能都将是Webpack的超集。

    Vite概述

    与Vue CLI类似,Vite也是一个提供基本项目脚手架和开发服务器的构建工具。

    然而,Vite并不是基于Webpack的,它有自己的开发服务器,利用浏览器中的原生ES模块。这种架构使得Vite比Webpack的开发服务器快了好几个数量级。Vite采用Rollup进行构建,速度也更快。

    Vite目前还处于测试阶段,看来Vite项目的目的并不是像Vue CLI那样的一体化工具,而是专注于提供一个快速的开发服务器和基本的构建工具。

    Vite怎么这么快?

    Vite开发服务器至少会比Webpack快10倍左右。对于一个基本的项目来说,与2.5秒相比,开发构建/重新构建的时间相差250ms。

    在一个较大的项目中,这种差异会变得更加明显。Webpack开发服务器在构建/重新构建时可能会慢到25-30秒,有时甚至更慢。与此同时,Vite开发服务器可能会以恒定的250ms的速度为同一个项目提供服务。

    这显然是开发经验和游戏规则改变的差异,Vite是如何做到这一点的?

    Webpack开发服务器架构

    Webpack的工作方式是,它通过解析应用程序中的每一个 importrequire ,将整个应用程序构建成一个基于JavaScript的捆绑包,并在运行时转换文件(例如Sass、TypeScript、SFC)。

    这都是在服务器端完成的,依赖的数量和改变后构建/重新构建的时间之间有一个大致的线性关系。

    Vite开发服务器架构

    Vite不捆绑应用服务器端。相反,它依赖于浏览器对JavaScript模块的原生支持(也就是ES模块,是一个比较新的功能)。

    浏览器将在需要时通过HTTP请求任何JS模块,并在运行时进行处理。Vite开发服务器将按需转换任何文件(如Sass、TypeScript、SFC)。

    这种架构避免了服务器端对整个应用的捆绑,并利用浏览器高效的模块处理,提供了一个明显更快的开发服务器。

    Vite的缺点

    你可能已经明白了,Vite的主要特点是它的开发服务器快得离谱。

    如果没有这个功能,可能就不会再讨论了,因为与Vue CLI相比,它确实没有其他的功能,而且确实有一些缺点。

    由于Vite使用了JavaScript模块,所以最好让依赖关系也使用JavaScript模块。虽然大多数现代JS包都提供了这一点,但一些老的包可能只提供CommonJS模块。

    Vite可以将CommonJS转换为JavaSript模块,但在一些边缘情况下它可能无法做到。当然,它还需要支持JavaScript模块的浏览器。

    与Webpack/Vue CLI不同,Vite无法创建针对旧版浏览器、web components等的捆绑包。

    而且,与Vue CLI不同,开发服务器和构建工具是不同的系统,导致在生产与开发中可能出现不一致的行为。

    Vue CLI vs Vite总结

    Vue CLI 优点Vue CLI 缺点
    经历过战斗考验,可靠开发服务器速度与依赖数量成反比与Vue 2兼容可以捆绑任何类型的依赖关系插件生态系统可以针对不同的目标进行构建
    Vite 优点Vite 缺点
    开发服务器比Webpack快10-100倍只能针对现代浏览器(ES2015+)将code-splitting作为优先事项与CommonJS模块不完全兼容处于测试阶段,仅支持Vue 3最小的脚手架不包括Vuex、路由器等不同的开发服务器与构建工具

    那么判决结果是什么?

    对于有经验的Vue开发来说,Vite是一个很好的选择,因为它的开发服务器速度快得离谱,让Webpack看起来像史前时代。

    但是,对于喜欢一些手把手的Vue新开发人员来说,或者,对于使用遗留模块和需要复杂构建的大型项目来说,Vue CLI很可能在目前仍然是必不可少的。

    Vite的未来

    虽然上面的比较主要集中在Vite和Vue CLI的现状上,但仍有几点需要考虑:

    • 仅当浏览器中的JavaScript模块支持得到改善时,Vite才会有所改善。
    • 随着JS生态系统的追赶,更多的软件包将支持JavaScript模块,减少Vite无法处理的边缘情况。
    • Vite仍处于测试阶段--功能可能会有变化。
    • 有可能Vue CLI最终会结合Vite,这样你就不用再使用其中一个了。

    参考

    • Vite and VitePress, Evan You, VueConf Toronto 2020
    • Vite - GitHub
    • Vue CLI - GitHub

    原文:blog.zhangbing.site/2020/12/18/…
    来源:vuejsdevelopers.com


    起源地下载网 » Vite使Vue CLI过时了吗?

    常见问题FAQ

    免费下载或者VIP会员专享资源能否直接商用?
    本站所有资源版权均属于原作者所有,这里所提供资源均只能用于参考学习用,请勿直接商用。若由于商用引起版权纠纷,一切责任均由使用者承担。更多说明请参考 VIP介绍。
    提示下载完但解压或打开不了?
    最常见的情况是下载不完整: 可对比下载完压缩包的与网盘上的容量,若小于网盘提示的容量则是这个原因。这是浏览器下载的bug,建议用百度网盘软件或迅雷下载。若排除这种情况,可在对应资源底部留言,或 联络我们.。
    找不到素材资源介绍文章里的示例图片?
    对于PPT,KEY,Mockups,APP,网页模版等类型的素材,文章内用于介绍的图片通常并不包含在对应可供下载素材包内。这些相关商业图片需另外购买,且本站不负责(也没有办法)找到出处。 同样地一些字体文件也是这种情况,但部分素材会在素材包内有一份字体下载链接清单。
    模板不会安装或需要功能定制以及二次开发?
    请QQ联系我们

    发表评论

    还没有评论,快来抢沙发吧!

    如需帝国cms功能定制以及二次开发请联系我们

    联系作者

    请选择支付方式

    ×
    迅虎支付宝
    迅虎微信
    支付宝当面付
    余额支付
    ×
    微信扫码支付 0 元