Vant 在vue-cli 4.x中按需加載操作
在vue-cli 4.x中使用vant出現(xiàn)的問題,在這里記錄一下
一. 如果使用按需加載,需要下載babel-plugin-import轉(zhuǎn)換一下,下載 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",{
"libraryName":"vant",
"style":true
}
]
]
}
接下來重啟項目一下。
補充知識:vue cli 3 升級到 vue cli 4 方法步驟及升級點總結(jié)
簡介:vue cli 4 官方已經(jīng)更新有一段時間了,現(xiàn)在是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 執(zhí)行成功,但是執(zhí)行 vue -V 輸出的還是3.5.6(我以前安裝的版本),
于是又重新執(zhí)行 npm install -g @vue/cli,顯示成功,執(zhí)行 vue -V 輸出的還是3.5.6,
一臉懵逼 ,然后重啟電腦,再執(zhí)行vue -V 輸出 @vue/cli 4.0.5,解決 。
二.在項目根目錄下執(zhí)行
vue upgrade
然后出現(xiàn)

提示 繼續(xù)升級這些插件嗎? 輸入 Y 即可.
三.等步驟二 執(zhí)行完會發(fā)現(xiàn)主要有 2 個文件被修改
1.文件 babel.config.js
主要是 babel 的預(yù)設(shè)由@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 導(dǎo)致的
它把 sass-loader由 ^7.x.x 的版本升級到了 ^8.0.0,而我項目中使用的是^7.1.0
所以升級一下自己項目的 sass-loader 就好了
執(zhí)行下面命令即可
npm i sass-loader@8.0.0 -D
2.然后第二個錯說沒有安裝core-js
vue cli 4把 core-js由 ^2.x.x 的版本升級到了 ^3.x.x
于是安裝一下
npm i core-js
然后重啟項目還是不行,看了下官方文檔和 babel 有關(guān)
main.js 代碼中
import '@babel/polyfill'
隱藏這個代碼
重啟好了
然后把 @babel/polyfill 換成 babel-polyfill 即可
npm i babel-polyfill
main.js 代碼中 改為
import 'babel-polyfill'
五.vue cli 4 主要升級點總結(jié)
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.默認(rèn)目錄結(jié)構(gòu)已更改
src/store.js 改為 src/store/index.js
src/router.js 改為 src/router/index.js
14.由于兼容性原因,仍支持 router&routerHistoryMode 選項 preset.json
但是現(xiàn)在建議使用它來 plugins: { '@vue/cli-plugin-router': { historyMode: true } }
獲得更好的一致性
15.api.hasPlugin('vue-router')不再受支持,現(xiàn)在 api.hasPlugin('router')
16.lintOnSave 選項的默認(rèn)值(未指定時)從 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)
參考鏈接
以上這篇Vant 在vue-cli 4.x中按需加載操作就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
vue 使用v-if切換輸入框時導(dǎo)致輸入框的數(shù)據(jù)內(nèi)容沒有清空的問題解決(兩種解決方法)
這篇文章主要介紹了vue 使用v-if切換輸入框時導(dǎo)致輸入框的數(shù)據(jù)內(nèi)容沒有清空的問題解決,本文給大家分享兩種解決方法,需要的朋友可以參考下2023-05-05
Vue數(shù)據(jù)驅(qū)動模擬實現(xiàn)1
這篇文章主要介紹了Vue數(shù)據(jù)驅(qū)動模擬實現(xiàn)的相關(guān)資料,允許采用簡潔的模板語法聲明式的將數(shù)據(jù)渲染進(jìn)DOM,且數(shù)據(jù)與DOM綁定在一起,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-01-01
vue-cli 3如何使用vue-bootstrap-datetimepicker日期插件
這篇文章主要介紹了vue-cli 3如何使用vue-bootstrap-datetimepicker日期插件,幫助大家更好的理解和學(xué)習(xí)使用vue框架,感興趣的朋友可以了解下2021-02-02
vue cli 3.0下配置開發(fā)環(huán)境下的sourcemap問題
這篇文章主要介紹了vue cli 3.0下配置開發(fā)環(huán)境下的sourcemap問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2024-06-06

