1. 程式人生 > 程式設計 >Vant 在vue-cli 4.x中按需載入操作

Vant 在vue-cli 4.x中按需載入操作

在vue-cli 4.x中使用vant出現的問題,在這裡記錄一下

一. 如果使用按需載入,需要下載babel-plugin-import轉換一下,下載 babel-plugin-import

cnpm install babel-plugin-import -D

**二. 在根目錄中找到 babel.config.js 檔案,新增欄位 **

"plugins": [
  ["import",{
   "libraryName":"vant","style":true
   }
  ]
 ]
最終我的配置是這樣的
module.exports = {
 presets: [
  '@vue/cli-plugin-babel/preset',],"plugins": [
  ["import","style":true
   }
  ]
 ]
}

接下來重啟專案一下。

補充知識:vue cli 3 升級到 vue cli 4 方法步驟及升級點總結

官方升級英文文件,中文文件相對滯後。

簡介:vue cli 4 官方已經更新有一段時間了,現在是4.0.5 版本,看了官方文件大概有二十幾點的更新,還是乾貨滿滿呀,值得升級一下,下面是升級步驟。

一.首先,在全域性安裝最新的 Vue CLI:

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

檢查安裝的版本

vue -V # 輸出:@vue/cli 4.x.x 說明@vue/cli 4安裝成功( vue cli 3的版本會輸出 3.x.x )

踩坑記錄

npm install -g @vue/cli 執行成功,但是執行 vue -V 輸出的還是3.5.6(我以前安裝的版本),

於是又重新執行 npm install -g @vue/cli,顯示成功,執行 vue -V 輸出的還是3.5.6,

一臉懵逼 ,然後重啟電腦,再執行vue -V 輸出 @vue/cli 4.0.5,解決 。

二.在專案根目錄下執行

vue upgrade

然後出現

Vant 在vue-cli 4.x中按需載入操作

提示 繼續升級這些外掛嗎? 輸入 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',{
    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

然後報下面的錯

Vant 在vue-cli 4.x中按需載入操作

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 [email protected] -D

2.然後第二個錯說沒有安裝core-js

vue cli 4把 core-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-loader由 v7 的版本升級到了 v8

3.core-js由 v2 的版本升級到了 v3

4.webpack-chain由 v4 的版本升級到了 v6

5.css-loader由 v1 的版本升級到了 v3

6.url-loader由 v1 的版本升級到了 v2

7.file-loader由 v3 的版本升級到了 v4

8.copy-webpack-plugin由 v4 的版本升級到了 v5

9.terser-webpack-plugin由 v1 的版本升級到了 v2

10.@vue/cli-plugin-pwa由 v3 的版本升級到了 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 jest由 v23 升級到v24

21.@vue/cli-plugin-typescript 更好的ts(x)支援 ,勝過js(x)

參考連結

vue cli 4 官方英文升級文件

以上這篇Vant 在vue-cli 4.x中按需載入操作就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支援我們。