vue cli 3 升级到 vue cli 4 方法步骤及升级点总结

vue cli 3 升级到 vue cli 4 方法步骤及升级点总结

官方升级英文文档中文文档相对滞后。css

简介:vue cli 4 官方已经更新有一段时间了,如今是4.0.5 版本,看了官方文档大概有二十几点的更新,仍是干货满满呀,值得升级一下,下面是升级步骤。vue

一.首先,在全局安装最新的 Vue CLI:webpack

npm install -g @vue/cli
# OR
yarn global add @vue/cli

检查安装的版本web

vue -V  # 输出:@vue/cli 4.x.x  说明@vue/cli 4安装成功( vue cli 3的版本会输出 3.x.x )

踩坑记录vue-router

npm install -g @vue/cli 执行成功,可是执行 vue -V 输出的仍是3.5.6(我之前安装的版本),vuex

因而又从新执行 npm install -g @vue/cli,显示成功,执行 vue -V 输出的仍是3.5.6vue-cli

一脸懵逼 ,而后重启电脑,再执行vue -V 输出 @vue/cli 4.0.5,解决 。typescript

二.在项目根目录下执行npm

vue upgrade

而后出现
在这里插入图片描述json

提示 继续升级这些插件吗? 输入 Y 便可.

三.等步骤二 执行完会发现主要有 2 个文件被修改

1.文件 babel.config.js

主要是 babel 的预设由@vue/app 改为了@vue/cli-plugin-babel/preset

原来的

module.exports = {
  presets: [
    '@vue/app', // 这行
    [
      '@babel/preset-env',
      {
        useBuiltIns: 'entry'
      }
    ]
  ]
}

升级后的

module.exports = {
  presets: [
    '@vue/cli-plugin-babel/preset', // 这行
    [
      '@babel/preset-env',
      {
        useBuiltIns: 'entry'
      }
    ]
  ]
}

2.文件 package.json (package-lock.json 也会更改)

主要是依赖升级

原来的

{
  "@vue/cli-plugin-babel": "^3.11.0",
  "@vue/cli-plugin-eslint": "^3.11.0",
  "@vue/cli-service": "^3.11.0"
}

升级后的

{
  "@vue/cli-plugin-babel": "^4.0.5",
  "@vue/cli-plugin-eslint": "^4.0.5",
  "@vue/cli-service": "^4.0.5"
}

四.而后启动项目

npm run serve

而后报下面的错

在这里插入图片描述

1.第一个错(警告)

WARN  A new version of sass-loader is available. Please upgrade for best experience.

这行是 vue cli 4 升级了本身的依赖 sass-loader 致使的

它把 sass-loader^7.x.x 的版本升级到了 ^8.0.0,而我项目中使用的是^7.1.0

因此升级一下本身项目的 sass-loader 就行了

执行下面命令便可

npm i sass-loader@8.0.0 -D

2.而后第二个错说没有安装core-js

vue cli 4core-js^2.x.x 的版本升级到了 ^3.x.x

因而安装一下

npm i core-js

而后重启项目仍是不行,看了下官方文档和 babel 有关

main.js 代码中

import '@babel/polyfill'

隐藏这个代码

重启好了

而后把 @babel/polyfill 换成成 babel-polyfill 便可

npm i babel-polyfill

main.js 代码中 改成

import 'babel-polyfill'

五.vue cli 4 主要升级点总结

1."@vue/cli-plugin-babel", "@vue/cli-plugin-eslint", "@vue/cli-service"v3 的版本升级到了 v4

2.sass-loaderv7 的版本升级到了 v8

3.core-jsv2 的版本升级到了 v3

4.webpack-chainv4 的版本升级到了 v6

5.css-loaderv1 的版本升级到了 v3

6.url-loaderv1 的版本升级到了 v2

7.file-loaderv3 的版本升级到了 v4

8.copy-webpack-pluginv4 的版本升级到了 v5

9.terser-webpack-pluginv1 的版本升级到了 v2

10.@vue/cli-plugin-pwav3 的版本升级到了 v4

11.新增插件 vue add vuex vue add router

12.pug-plain已重命名为pug-plain-loader

13.默认目录结构已更改

src/store.js 改成 src/store/index.js

src/router.js 改成 src/router/index.js

14.因为兼容性缘由,仍支持 router&routerHistoryMode 选项 preset.json

可是如今建议使用它来 plugins: { '@vue/cli-plugin-router': { historyMode: true } }

得到更好的一致性

15.api.hasPlugin('vue-router')再也不受支持,如今 api.hasPlugin('router')

16.lintOnSave 选项的默认值(未指定时)从 true 更改成 default

17.废弃vue-cli-service test:e2e

18.@vue/cli-plugin-e2e-nightwatch Nightwatch.js已从0.9升级到1.x

19.@vue/cli-plugin-unit-mocha 升级到Mocha 6

20.@vue/cli-plugin-unit-jest jestv23 升级到v24

21.@vue/cli-plugin-typescript 更好的ts(x)支持 ,赛过js(x)

参考连接

vue cli 4 官方英文升级文档