這篇文章將為大家詳細講解有關(guān)如何將項目升級到vue-cli3,小編覺得挺實用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。
為普安等地區(qū)用戶提供了全套網(wǎng)頁設計制作服務,及普安網(wǎng)站建設行業(yè)解決方案。主營業(yè)務為成都做網(wǎng)站、網(wǎng)站建設、普安網(wǎng)站設計,以傳統(tǒng)方式定制建設網(wǎng)站,并提供域名空間備案等一條龍服務,秉承以專業(yè)、用心的態(tài)度為用戶提供真誠的服務。我們深信只要達到每一位用戶的要求,就會得到認可,從而選擇與我們長期合作。這樣,我們也可以走得更遠!
一. 原以為升級vue-cli3的路線是這樣的:
創(chuàng)建vue-cli3項目,按原有項目的配置選好各項配置
遷移目錄
src->src static->public
對比新舊 package.json
,然后 yarn install
,完畢。
然鵝... 運行項目,報錯 You are using the runtime-only build of Vue......
:
然后去查了下舊項目的相關(guān)字眼文件:
噢,原來是vue-cli3的webpack相關(guān)文件都得自己寫。于是乎根據(jù)官網(wǎng)的指引,在根目錄創(chuàng)建了 vue.config.js
此時粗略配置:
chainWebpack: config => { config.module .rule('vue') .use('vue-loader') .loader('vue-loader') .tap(options => { options.compilerOptions.preserveWhitespace = false return options }) config.resolve.alias .set('vue$', 'vue/dist/vue.esm.js') .set('@', resolve('src')) }
二. 此時勉強能跑起來,但后續(xù)遇到了這些坑:
#1
public 靜態(tài)資源不加載
``` const CopyWebpackPlugin = require('copy-webpack-plugin') // .... // 確保靜態(tài)資源 config.resolve.extensions = ['.js', '.vue', '.json', '.css'] config.plugins.push( new CopyWebpackPlugin([{ from: 'public/', to: 'public' }]), ) ```
#2
Chrome 查看樣式時無法找到源文件
原因: vue-cli3
里默認關(guān)閉 sourceMap
,樣式都會被打包到首頁。 解決: 需要自己配置打開
// 讓樣式找到源 css: { sourceMap: true },
#3
生產(chǎn)環(huán)境的 debuger
和 console
無法通過 uglifyjs-webpack-plugin
和 uglify-es
剔除
原因:不支持 es6
, 需要配置 babel
( uglify-es
按配置填會顯示不存在選項)
解決:插件terser
``` const TerserPlugin = require('terser-webpack-plugin') if (process.env.NODE_ENV === 'production') { // 為生產(chǎn)環(huán)境修改配置... new TerserPlugin({ cache: true, parallel: true, sourceMap: true, // Must be set to true if using source-maps in production terserOptions: { compress: { drop_console: true, drop_debugger: true } } }) } else { // 為開發(fā)環(huán)境修改配置... } ```
#4
無法在 config
目錄下配置不同環(huán)境的 API_URL
,用于跨域請求
原因: vue-cli3 中需要遵循變量規(guī)則,使用 VUE_APP 前綴
官方規(guī)則: 在客戶端側(cè)代碼中使用環(huán)境變量
解決:于是你需要創(chuàng)建如下幾個文件:
.local
也可以加在指定模式的環(huán)境文件上,比如 .env.development.local
將會在 development
模式下被載入,且被 git 忽略。
文件內(nèi)容:
// env.development.local NODE_ENV = development VUE_APP_URL = http://xxx.x.xxx/
#5
vue-cli代理轉(zhuǎn)發(fā)控制臺反復打印 "WebSocket connection to'ws://localhost..."
解決方法:
vue.config.js
中配置 devServer.proxy
的 ws
為 false
結(jié)合上述兩步,相對應的 vue.config.js
,需要這么寫:
const env = process.env.NODE_ENV let target = process.env.VUE_APP_URL const devProxy = ['/api', '/'] // 代理 // 生成代理配置對象 let proxyObj = {}; devProxy.forEach((value, index) => { proxyObj[value] = { ws: false, target: target, // 開啟代理:在本地會創(chuàng)建一個虛擬服務端,然后發(fā)送請求的數(shù)據(jù),并同時接收請求的數(shù)據(jù),這樣服務端和服務端進行數(shù)據(jù)的交互就不會有跨域問題 changeOrigin: true, pathRewrite: { [`^${value}`]: value } }; }) // .... devServer: { open: true, host: 'localhost', port: 8080, proxy: proxyObj }
最后貼上我的 vue.config.js
:
const CopyWebpackPlugin = require('copy-webpack-plugin') const TerserPlugin = require('terser-webpack-plugin') const path = require('path') const env = process.env.NODE_ENV let target = process.env.VUE_APP_URL const devProxy = ['/api', '/'] // 代理 // 生成代理配置對象 let proxyObj = {}; devProxy.forEach((value, index) => { proxyObj[value] = { ws: false, target: target, // 開啟代理:在本地會創(chuàng)建一個虛擬服務端,然后發(fā)送請求的數(shù)據(jù),并同時接收請求的數(shù)據(jù),這樣服務端和服務端進行數(shù)據(jù)的交互就不會有跨域問題 changeOrigin: true, pathRewrite: { [`^${value}`]: value } }; }) function resolve (dir) { return path.join(__dirname, dir) } module.exports = { publicPath: '/', // 讓樣式找到源 css: { sourceMap: true }, configureWebpack: config => { // 確保靜態(tài)資源 config.resolve.extensions = ['.js', '.vue', '.json', '.css'] config.plugins.push( new CopyWebpackPlugin([{ from: 'public/', to: 'public' }]), ) if (process.env.NODE_ENV === 'production') { // 為生產(chǎn)環(huán)境修改配置... new TerserPlugin({ cache: true, parallel: true, sourceMap: true, // Must be set to true if using source-maps in production terserOptions: { compress: { drop_console: true, drop_debugger: true } } }) } else { // 為開發(fā)環(huán)境修改配置... } }, chainWebpack: config => { config.module .rule('vue') .use('vue-loader') .loader('vue-loader') .tap(options => { options.compilerOptions.preserveWhitespace = false return options }) config.resolve.alias .set('vue$', 'vue/dist/vue.esm.js') .set('@', resolve('src')) }, devServer: { open: true, host: 'localhost', port: 8080, proxy: proxyObj } }
三. Eslint相關(guān)報錯及配置
module.exports = { root: true, env: { node: true }, 'extends': [ 'plugin:vue/essential', '@vue/standard' ], rules: { 'generator-star-spacing': 'off', 'object-curly-spacing': 'off', // 最常出現(xiàn)的錯誤 'no-unused-vars': 'off', // 最常出現(xiàn)的錯誤 "vue/no-use-v-if-with-v-for": ["error", { "allowUsingIterationVar": true }], 'no-console': process.env.NODE_ENV === 'production' ? 'error' : 'off', 'no-debugger': process.env.NODE_ENV === 'production' ? 'error' : 'off' }, parserOptions: { parser: 'babel-eslint' } }
最后的最后,跑個項目
yarn serve
yarn build
關(guān)于“如何將項目升級到vue-cli3”這篇文章就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,使各位可以學到更多知識,如果覺得文章不錯,請把它分享出去讓更多的人看到。
網(wǎng)頁標題:如何將項目升級到vue-cli3
URL地址:http://chinadenli.net/article28/pgoscp.html
成都網(wǎng)站建設公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站制作、移動網(wǎng)站建設、外貿(mào)網(wǎng)站建設、Google、App設計、網(wǎng)站內(nèi)鏈
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)