网站首页 > 技术文章 正文
近日,Vue 的作者尤雨溪在 Medium 上宣布正式发布 Vue CLI 3.0,它也将为很多开发者带来期待已久的新特性。
丰富的内置功能
尤雨溪表示,Vue CLI 3.0 与其他的版本完全不同,它经历了重构,目的是:
- 尽可能减少现代前端工具在配置上的烦恼,尤其是在开发者将多个工具混合使用时;
- 尽可能在工具链中加入最佳实践,并让其成为 Vue 应用程序的默认实践。
Vue CLI 的核心目标是为基于 webpack 4 构建的预配置提供构建设置,目标是最大限度地减少开发人员配置的次数,所以 Vue CLI 3 对具有以下特点的项目都支持开箱即用:
- 预配置 webpack 功能,如模块热替换、代码拆分、 摇树优化(tree-shaking)、高效持久化缓存等;
- 通过 Babel 7 + preset-env(Babel 插件)对 ES2017 进行转换和基于使用情况注入 polyfill
- 支持 PostCSS(默认启用 autoprefixer)和所有主要的 CSS 预处理器
- Modern mode:并行发布原生 ES2017 +bundle 和传统 bundle(详情如下)
- 多页面模式:构建具有多个 HTML / JS 入口点的应用程序
- 构建目标:将 Vue 单文件组件构建成为库或原生 Web 组件(详情如下)
此外,你可以在创建新项目时混合选用多种集成:
- TypeScript
- PWA
- Vue Router & Vuex
- ESLint / TSLint / Prettier
- 用 Jest 或 Mocha 进行单元测试
- 用 Cypress 或者 Nightwatch 进行 E2E 测试
而且,Vue CLI 能确保上述所有功能可以很好地协同使用。
无需eject即可配置
上面列出的所有功能都支持零配置:利用 Vue CLI 3 构建项目时,它会安装 Vue CLI 运行时服务(@ vue / cli-service),选择功能插件,生成必要的配置文件。也就是说,你只需要专注于你的代码即可。
CLI 工具去掉潜在的依赖关系的同时,通常也会丧失对这些依赖关系进行微调的能力,因此,用户通常必须“eject”,以便进行更改。这样做的缺点是,一旦弹出,从长远来看,你将无法升级到最新版本的工具了。
尤雨溪认为以低级别形式访问 configs 具有很重要的意义,但他不想抛弃那些“eject”的用户,所以他找出了一种无需eject的配置方法。
对于 Babel、TypeScript 和 PostCSS 等第三方集成来说,Vue CLI 会尊重这些工具的配置文件。webpack 用户可以使用 webpack-merge 将简单对象合并到最终配置中,或通过 webpack-chain 进行精确定位和调整现有的加载器和插件。
此外,Vue CLI 附带 vue inspect 命令可帮助你检查内部 Webpack 配置。最大的好处是,只需小调整不需eject,你仍可以升级 CLI service 和插件进行修复或更新。
可扩展的插件系统
Vue CLI 3 插件系统非常强大:它可以在应用程序的 scaffolding 阶段注入依赖项和文件,并调整应用程序的 webpack 配置,或在开发期间向 CLI service 注入其他命令。大多数像 TypeScript 这样的内置集成都使用 plugin API (https://github.com/vuejs/vue-cli/blob/dev/packages/%40vue/cli-service/lib/PluginAPI.js)实现插件功能。
而且,Vue CLI 3 不再有“template”, 相反,现在你可以进行远程设置,与其他开发人员共享你的插件和选项。
图形用户界面 (GUI)
得益于 Guillaume CHAU(Vue.js 核心团队)的出色表现,Vue CLI 3 还附带了一个完整的 GUI,不仅可以创建新项目,还可以管理项目中的插件和任务,例如:
它不需要 Electron,只需用vue ui启动它。
注意:虽然 Vue CLI 3 已处于稳定版本,但 UI 仍处于测试阶段,后续会持续更新。
Instant Prototyping
有时我们需要即时访问工作环境以获得新灵感,此时等待 npm install 就成为了困扰的事。使用 Vue CLI 3 的 vue serve 命令,你只需要启用 Vue 单文件组件就可进行原型设计:
更多功能
Modern Mode
有了 Babel,你可以使用 ES2015 + 中所有最新的语言功能,但这也意味着我们需要转译和 polyfill bundle 以支持旧版本的浏览器。这些转换后的包通常比原始的原生 ES2015 + 代码更冗长,解析和运行速度也更慢。鉴于今天大多数现代浏览器都支持原生 ES2015 + 代码,因此它也必须支持较旧的代码,但对浏览器来说,运行这种低效率的代码是一种浪费。
用“Modern Mode”可帮你解决此问题。在构建时,使用以下命令:
vue-cli-service build --modern
Vue CLI 将生成两个版本的应用程序:一个是支持 ES 模块的现代浏览器的现代软件包,以及一个不支持 ES 模块的旧版浏览器的旧版软件包。
生成的 HTML 文件自动采用 Phillip Walton(https://philipwalton.com/articles/deploying-es2015-code-in-production-today/)帖子中讨论的技术:
- <script type="module"> 可在支持它的浏览器中加载现代软件包,也可用< link rel="modulepreload" >进行预加载;
- 加载旧版的软件包可以使用<script nomodule>,支持 ES 模块的浏览器会自动忽略该软件包;
- <script nomodule>的修复程序在 Safari 10 会自动注入。
对于 Hello World 应用程序,现代软件包已经缩小了 16%。在实际应用中,现代软件包通常会显著加快解析和评测速度,从而提高应用程序的加载性能。
尤雨溪还表示:
我们没有将 modern mode 作为默认设置的原因是,如果使用 CORS / CSP,你需要更长的构建时间和一些额外的配置。
构建 Web 组件
现在,你可以在 Vue CLI 3 项目中将任何 *.vue 组件构建成 Web 组件:
vue-cli-service build --target wc --name my-element src/MyComponent.vue
这将生成一个 JavaScript 包,它将内部 Vue 组件包装,并注册为页面上的原生自定义元素,然后可以将其看做作< my-element >。
你甚至可以将多个 *.vue 组件放到具有多块代码拆分的包中:
vue-cli-service build --target wc-async 'src/components/*.vue'
在生成的包中包含一个小的入口文件,它将所有组件注册为原生自定义元素,但只有在页面上首次实例化相应的自定义元素,才能获取底层 Vue 组件的代码。
使用 Vue CLI 3,还可以使用相同的代码库来构建应用程序、UMD 库或原生 Web 组件。
最后,尤雨溪说,Vue CLI 3 现在可作为 Vue 应用程序的标准构建工具,但这仅仅是个开始。如上所述,Vue CLI 的长期目标是将当前和未来的最佳实践融入工具链中,最终为用户提供高性能的应用程序。
- 上一篇: 运行 npm run xxx 的时候发生了什么?
- 下一篇: 为了实践微前端,重构了自己的导航网站
猜你喜欢
- 2024-09-27 一文带你彻底搞懂 NPM 知识点「进阶篇」
- 2024-09-27 深入探索Vue3:将您的项目打包为生产版本
- 2024-09-27 「Vue3教程」创建你的第一个Vue 3项目
- 2024-09-27 Vue3亮点:打造和发布你自己的组件库,简单步骤助你成为前端大神
- 2024-09-27 mac电脑如何安装VUE环境及预览(mac怎么安装vue)
- 2024-09-27 vue实战——自定义基础路径,端口号
- 2024-09-27 为了实践微前端,重构了自己的导航网站
- 2024-09-27 运行 npm run xxx 的时候发生了什么?
- 2024-09-27 Vue全家桶-使用总结(国家基本药物使用情况分析总结)
- 2024-09-27 vue package.json 配置解析(vue-json-pretty)
- 1515℃桌面软件开发新体验!用 Blazor Hybrid 打造简洁高效的视频处理工具
- 577℃Dify工具使用全场景:dify-sandbox沙盒的原理(源码篇·第2期)
- 514℃MySQL service启动脚本浅析(r12笔记第59天)
- 487℃服务器异常重启,导致mysql启动失败,问题解决过程记录
- 486℃启用MySQL查询缓存(mysql8.0查询缓存)
- 470℃「赵强老师」MySQL的闪回(赵强iso是哪个大学毕业的)
- 450℃mysql服务怎么启动和关闭?(mysql服务怎么启动和关闭)
- 448℃MySQL server PID file could not be found!失败
- 最近发表
-
- 宝塔面板Nginx如何提高网站访问速度?
- 接口调试工具ApiPost中form-data/x-www-form-urlencoded/raw区别
- 高并发场景下,Nginx性能如何提升10倍?
- 高并发场景下,Nginx如何抗住千万级流量?
- 浏览器中在线预览pdf文件,pdf.mjs插件实现web预览pdf
- 为什么你的网站加载慢?90%的人忽略了这2个设置。
- 别再无脑复制Nginx配置了!掌握这10个"性能核弹"级参数
- 你的Nginx配置,可能就是你网站最慢的一环,注意这几个优化参数
- 深入浅出HTTP压缩技术(http2压缩)
- C程序设计之:1-1/2+1/3-... + 1/n 的和
- 标签列表
-
- cmd/c (90)
- c++中::是什么意思 (83)
- 主键只能有一个吗 (66)
- c#console.writeline不显示 (75)
- pythoncase语句 (81)
- es6includes (73)
- windowsscripthost (67)
- apt-getinstall-y (86)
- node_modules怎么生成 (76)
- c++int转char (75)
- static函数和普通函数 (76)
- el-date-picker开始日期早于结束日期 (70)
- js判断是否是json字符串 (67)
- checkout-b (67)
- c语言min函数头文件 (68)
- asynccallback (71)
- localstorage.removeitem (74)
- vector线程安全吗 (70)
- & (66)
- java (73)
- js数组插入 (83)
- mac安装java (72)
- eacces (67)
- 查看mysql是否启动 (70)
- 无效的列索引 (74)