webpack4+Vue搭建自己的Vue-cli項(xiàng)目過程分享
前言
對(duì)于vue-cli的強(qiáng)大,使用過的人都知道,極大的幫助我們降低了vue的入門門檻
最近在看webpack4,深感知識(shí)淺薄,這兩天也一直在思考cli的配置,借助一些別人的實(shí)踐,嘗試自己搭建vue的項(xiàng)目,這里使用webpack4版本,之前我在網(wǎng)上查找別人的vue項(xiàng)目搭建,但是都是webpack3的,所以寫了本文,如果有錯(cuò)誤,或者有什么問題,請(qǐng)大佬們指出
關(guān)于webpack的本文不會(huì)多說,請(qǐng)看webpack文檔
關(guān)于本文的github地址vue-MYCLI
你們的start是我發(fā)表的動(dòng)力!!!!!
前置知識(shí)
•熟悉 webpack4
•熟悉 vue
搭建基本骨架
npm init
安裝webpack4
npm install webpack webpack-cli --save-dev
在開始之前先實(shí)驗(yàn)一下環(huán)境
根目錄新建文件 index.html
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <meta http-equiv="X-UA-Compatible" content="ie=edge"> <title>Vue</title> </head> <body> <script src="./src/mian.js"></script> </body> </html>
根目錄新建文件 src/main.js
console.log("我是main");
根目錄新建文件webpack.config.js
const path = require('path') module.exports = { entry: './src/main.js', output: { path: path.resolve(__dirname, dist), filename: 'index.js' } }
打包js文件
npx webpack --config webpack.config.js
會(huì)看到一些報(bào)錯(cuò),只要構(gòu)建成功就ok
這里說明環(huán)境是沒有問題的
配置初始生成環(huán)境
開始安裝vue-loader吧
npm i webpack vue vue-loader -D //-D就是--save-dev
安裝完成后看輸出
提示安裝的依賴要安裝
npm install webpack css-loader -D
安裝完畢后新建src/app.vue
<template> <div> 你好 {{ data }} </div> </template> <script> export default { data(){ return { data: "Vue" } } } </script> <style scoped> </style>
.vue文件是無法直接運(yùn)行的,需要在webpack里面配置loader
這里參照某課的老師的方法,html用webpack生成(后面說明)
在根目錄新建index.js 刪除index.html
import Vue from 'vue' import App from './app.vue' const root = document.createElement('div') document.body.appendChild(root) new Vue({ render: (h) => h(App) }).$mount(root)
改寫webpack.config.js
const path = require('path') module.exports = { entry: path.resolve(__dirname, 'src/index.js'), //關(guān)于path模塊可以看看阮一峰的教程 http://javascript.ruanyifeng.com/nodejs/path.html#toc0 output: { path: path.resolve(__dirname, 'dist'), filename: 'index.js' }, module: { rules: [{ test: /\.vue$/, loader: 'vue-loader' }] } }
在package里面添加腳本
"build": "webpack --config webpack.config.js"
控制臺(tái)運(yùn)行
npm run build
不出意外會(huì)報(bào)錯(cuò)
這里有2個(gè)問題,一個(gè)是沒有指定mode 一個(gè)是沒有引用vue的插件
我們需要改寫webpack.config.js,在config里面加一行
mode: 'production', //暫時(shí)指定為生產(chǎn)環(huán)境
再次運(yùn)行npm run build 會(huì)報(bào)錯(cuò),需要安裝一個(gè)包
這個(gè)報(bào)錯(cuò),原本在vue-loader就有提示,不知道為什么現(xiàn)在沒有,運(yùn)行之前報(bào)錯(cuò)
Error: [vue-loader] vue-template-compiler must be installed as a peer dependency, or a compatible compiler implementation must be passed via options
安裝vue-template-compiler
npm install vue-template-compiler -D
再再次運(yùn)行npm run build
假如按步驟來不除意外這里可以打包成功了~~~~
我們需要驗(yàn)證打包文件時(shí)候是否正確,所以這里使用插件HtmlWebpackPlugin,幫我們自動(dòng)創(chuàng)建html文件,并且在后續(xù)的hash文件名上很有用,具體可以看官方介紹
npm install html-webpack-plugin -D
改webpack.config.js代碼
const path = require('path') const { VueLoaderPlugin } = require('vue-loader') var HtmlWebpackPlugin = require('html-webpack-plugin'); //引入插件 module.exports = { mode: 'production', //暫時(shí)指定為生產(chǎn)環(huán)境 entry: path.resolve(__dirname, 'src/index.js'), //關(guān)于path模塊可以看看阮一峰的教程 http://javascript.ruanyifeng.com/nodejs/path.html#toc0 output: { path: path.resolve(__dirname, 'dist'), filename: 'index.js' }, module: { rules: [{ test: /\.vue$/, loader: 'vue-loader' }] }, plugins: [ new VueLoaderPlugin(), new HtmlWebpackPlugin() ] }
npm run build打包一下,dist文件夾下面會(huì)有兩個(gè)文件
啟動(dòng)一個(gè)靜態(tài)服務(wù)器
打包Vue程序完成~~~~
至此完成了最基本的webpack配置
接下來我們要完成的的配置開發(fā)環(huán)境
配置開發(fā)環(huán)境
關(guān)于開發(fā)環(huán)境以及生成環(huán)境,webpack是需要區(qū)分的,根據(jù)文檔模塊,我決定在命令里面指定模式,相應(yīng)的就將開發(fā)環(huán)境以及生成環(huán)境分開,
這里我使用的是提起基本的webpack配置使用webpack-merge這個(gè)包來拼接我們webpack配置
npm i webpack-merge -D
修改配置文件
將各各環(huán)境的代碼區(qū)分開,webpack的結(jié)構(gòu)是這樣的
webpack.config.base.js
const path = require('path') const config = { entry: path.resolve(__dirname, '../src/index.js'), output: { path: path.resolve(__dirname, 'dist'), filename: 'index.js' }, module: { rules: [{ test: /\.vue$/, loader: 'vue-loader' }] } }
module.exports = config
webpack.config.build.js const { VueLoaderPlugin } = require('vue-loader') const HtmlWebpackPlugin = require('html-webpack-plugin') const merge = require('webpack-merge') const baseConfig = require('./webpack.config.base') const config = merge(baseConfig ,{ plugins: [ new VueLoaderPlugin(), new HtmlWebpackPlugin() ] })
module.exports = config
這里配置開發(fā)環(huán)境就是重頭戲了,我們使用webpack-dev-server
webpack-dev-server是一個(gè)小型的Node.js Express服務(wù)器,代碼都跑在內(nèi)存里面
安裝webpack-dev-server
npm install webpack-dev-server -D webpack.config.dev.js const webpack = require('webpack') const merge = require('webpack-merge') const baseConfig = require('./webpack.config.base') const { VueLoaderPlugin } = require('vue-loader') const HtmlWebpackPlugin = require('html-webpack-plugin') const config = merge(baseConfig, { devServer: { port: '8000', host: 'localhost', hot: true, //熱加載 //quiet: true //控制臺(tái)中不輸出打包的信息 }, plugins: [ new VueLoaderPlugin(), new HtmlWebpackPlugin(), new webpack.HotModuleReplacementPlugin() ] }) module.exports = config
最后在package里面添加腳本
"build": "webpack --mode=production --config build/webpack.config.build.js",
"dev": "webpack-dev-server --mode=development --progress --config build/webpack.config.dev.js"
執(zhí)行npm run dev查看控制臺(tái)
這就成功了,在瀏覽器里面輸入http://localhost:8000/,修改app.vue文件,實(shí)現(xiàn)了vue-cli的熱加載了~~~~
接下來完善一下,不能只有.vue文件的loader,其他的webpack也要認(rèn)識(shí)
我們配置一下圖片的loader,以及css的loader,同時(shí)css使用postcss進(jìn)行預(yù)處理
url-loader 用于將文件轉(zhuǎn)換為base64 URI file-loader是依賴loader
npm i url-loader file-loader -D
添加配置webpack.config.base.js>module>rules
{ test: /\.(gif|png|jpg|svg)$/, use: [{ loader: 'url-loader', options: { limit: 2048, name: 'resources/[path][name].[hash:8].[ext]' } }] },
配置css(vue-cli里面的實(shí)現(xiàn)非常友好,有機(jī)會(huì)可以去看看) 下面的是最簡(jiǎn)單的配置
npm install css-loader -D npm install style-loader -D npm install postcss-loader -D
添加配置webpack.config.base.js>module>rules (postcss不了解谷歌一下)
{ test: /\.css$/, use: [ 'css-loader', 'style-loader', { loader: 'postcss-loader', options: { sourceMap: true //啟用源映射支持,postcss-loader將使用其他加載器給出的先前源映射并相應(yīng)地更新它 } } ] } npm install autoprefixer -D
根目錄新建文件postcss.config.js,安裝autoprefixer (自動(dòng)添加瀏覽器前綴)
const autoprofixer = require('autoprefixer') module.exports = { plugins: [ autoprofixer() ] }
配置到這里基本的圖片以及css就配置完成了,運(yùn)行一下試試 npm run dev
我找src下面創(chuàng)建了assets/img/user.jpg
app.vue
<template> <div> 你好 {{ data }} <img src="./assets/img/user.jpg"> </div> </template> <script> export default { data(){ return { data: "Vue Cli" } } } </script> <style> div{ font-size: 20px; color: red; } img { width: 100px; } </style>
實(shí)現(xiàn)了開發(fā)環(huán)境的圖片以及css的配置
打包一下試試
build后生成的目錄是這樣的
這不是我們想要的,webpack把代碼,類庫,css都打包在一起,這樣不管是上線還是首屏加載都有影響,所以這里我們要優(yōu)化webpack
在處理之前想安裝一個(gè)可以幫助我們每次build之前自動(dòng)刪除上次build生成的文件的插件
clean-webpack-plugin這個(gè)插件不知道為什么,怎么配置路徑都沒效果
這里我使用rimraf來進(jìn)行刪除(vue-cli也是使用rimraf,但是他是寫在代碼里面)
npm install rimraf -D
在package里面變一下腳本,讓打包之前幫我們刪除之前到打包文件
"build-webpack": "webpack --mode=production --config build/webpack.config.build.js",
"delete": "rimraf dist",
"build": "npm run delete && npm run build-webpack"
分離打包c(diǎn)ss
它會(huì)將所有的入口 chunk(entry chunks)中引用的 *.css,移動(dòng)到獨(dú)立分離的 CSS 文件
npm install extract-text-webpack-plugin@next -D
因?yàn)殚_發(fā)環(huán)境和生產(chǎn)環(huán)境不一樣
我們需要將css部分的代碼分環(huán)境配置
1.將原先的css配置放到webpack.config.dev.js里面
2.在webpack.config.build.js里面重寫
module: { rules: [{ test: /\.css$/, use: ExtractTextPlugin.extract({ fallback: "style-loader", use: [ 'css-loader', { loader: 'postcss-loader', options: { sourceMap: true } } ] }) }] },
這樣的話,我們開發(fā)環(huán)境不影響依舊是之前到模式,build的時(shí)候用ExtractTextPlugin幫我們分離非js文件,實(shí)現(xiàn)css的分離打包
我們打包一下試試npm run build
分離js文件
接下來是分離js文件,就是將庫文件以及我們的代碼分離開,利于上線后的瀏覽器緩存,代碼會(huì)經(jīng)常變,庫不會(huì)經(jīng)常變
在webpack4之前js分離用的插件是CommonsChunkPlugin,不過這插件現(xiàn)在移除了,現(xiàn)在用的是optimization.splitChunks 來進(jìn)行公共代碼與第三方代碼的提取,splitChunks參數(shù)如下
optimization: { splitChunks: { chunks: "initial", // 代碼塊類型 必須三選一: "initial"(初始化) | "all"(默認(rèn)就是all) | "async"(動(dòng)態(tài)加載) minSize: 0, // 最小尺寸,默認(rèn)0 minChunks: 1, // 最小 chunk ,默認(rèn)1 maxAsyncRequests: 1, // 最大異步請(qǐng)求數(shù), 默認(rèn)1 maxInitialRequests: 1, // 最大初始化請(qǐng)求書,默認(rèn)1 name: () => {}, // 名稱,此選項(xiàng)課接收 function cacheGroups: { // 緩存組會(huì)繼承splitChunks的配置,但是test、priorty和reuseExistingChunk只能用于配置緩存組。 priority: "0", // 緩存組優(yōu)先級(jí) false | object | vendor: { // key 為entry中定義的 入口名稱 chunks: "initial", // 必須三選一: "initial"(初始化) | "all" | "async"(默認(rèn)就是異步) test: /react|lodash/, // 正則規(guī)則驗(yàn)證,如果符合就提取 chunk name: "vendor", // 要緩存的 分隔出來的 chunk 名稱 minSize: 0, minChunks: 1, enforce: true, reuseExistingChunk: true // 可設(shè)置是否重用已用chunk 不再創(chuàng)建新的chunk } } } }
官方包括這解釋,我并不是很看懂,所以打包策略并不是很好
在webpack.config.build.js>config
output: { filename: '[name].[chunkhash:8].js' }, optimization: { splitChunks: { chunks: "all", cacheGroups: { vendor: { test: /node_modules/, //這里雖然分離了,但是沒有做到按需引入,看官方配置也不是很明白 name: 'vendors', chunks: 'all' } } }, runtimeChunk: true }
build一下查看目錄,可以看出代碼與庫之間分離了
關(guān)于eslint,我就不引入的,有興趣可以討論一下
.gitignore
這里處理一下git 新建文件.gitignore
.DS_Store node_modules/ /dist/ npm-debug.log* yarn-debug.log* yarn-error.log* # Editor directories and files .idea .vscode *.suo *.ntvs* *.njsproj *.sln .editorconfig,
處理一下編譯器的統(tǒng)一配置
新建文件 .editorconfig,(關(guān)于editorconfig,以及配置解釋)
root = true [*] charset = utf-8 indent_style = space indent_size = 2 end_of_line = lf insert_final_newline = true trim_trailing_whitespace = true
還有一點(diǎn)要注意,假如沒有效果,vscode需要安裝一個(gè)插件EditorConfig for VS Code,其他編譯器不太清楚
.babelrc
處理一下ES6,以及js文件的webpack的loader配置
今天裝了babel-loader8.0.0 報(bào)錯(cuò)報(bào)一上午,心態(tài)都搞崩了,所以這里我使用的是7版本
npm install babel-loader@7 babel-core babel-preset-env -D
在webpack.config.base.js>module>rules里面添加代碼
{ test: /\.js$/, exclude: /node_modules/, loader: 'babel-loader' }
新建文件 .babelrc
{ "presets": [ "env" ] }
首先檢查開發(fā)環(huán)境
我新建了一個(gè)es6語法的js 導(dǎo)入到app.vue里面
運(yùn)行結(jié)果
最后
至此,基本的vue項(xiàng)目骨架的搭建完畢了,當(dāng)然他沒有vue-cli那么強(qiáng)大,或許最大的益處是讓我們熟悉一個(gè)vue項(xiàng)目的大致webpack配置,當(dāng)然我們可以一步一步的優(yōu)化項(xiàng)目,希望對(duì)大家有所幫助,如果大家有任何疑問請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!
相關(guān)文章
vue實(shí)現(xiàn)form表單與table表格的數(shù)據(jù)關(guān)聯(lián)功能示例
這篇文章主要介紹了vue實(shí)現(xiàn)form表單與table表格的數(shù)據(jù)關(guān)聯(lián)功能,涉及vue.js表單事件響應(yīng)及頁面元素屬性動(dòng)態(tài)操作相關(guān)實(shí)現(xiàn)技巧,需要的朋友可以參考下2019-01-01vue中el-date-picker選擇日期的限制的項(xiàng)目實(shí)踐
ElementUI的el-date-picker使用時(shí),有時(shí)候想要限制用戶選擇的時(shí)間范圍,本文就來介紹了vue中el-date-picker選擇日期的限制的項(xiàng)目實(shí)踐,感興趣的可以了解一下2023-10-10vue3+ts+echarts實(shí)現(xiàn)按需引入和類型界定方式
這篇文章主要介紹了vue3+ts+echarts實(shí)現(xiàn)按需引入和類型界定方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-10-10vue cli如何配置開發(fā)環(huán)境下的sourcemap
這篇文章主要介紹了vue cli如何配置開發(fā)環(huán)境下的sourcemap問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-06-06vue 通過下拉框組件學(xué)習(xí)vue中的父子通訊
這篇文章主要介紹了vue 通過下拉框組件學(xué)習(xí)vue中的父子通訊的相關(guān)知識(shí),文中涉及到了父組件,子組件的實(shí)現(xiàn)代碼,需要的朋友可以參考下2017-12-12vue3實(shí)現(xiàn)在新標(biāo)簽中打開指定網(wǎng)址的方法
我希望點(diǎn)擊查看按鈕的時(shí)候,能夠在新的標(biāo)簽頁面打開這個(gè)文件的地址進(jìn)行預(yù)覽,該如何實(shí)現(xiàn)呢,下面小編給大家?guī)砹嘶趘ue3實(shí)現(xiàn)在新標(biāo)簽中打開指定的網(wǎng)址,感興趣的朋友跟隨小編一起看看吧2024-07-07Vue3中Vite和Vue-cli的特點(diǎn)與區(qū)別詳解
vue-cli是Vue早期推出的一款腳手架,使用webpack創(chuàng)建Vue項(xiàng)目,可以選擇安裝需要的各種插件,比如Vuex、VueRouter,下面這篇文章主要給大家介紹了關(guān)于Vue3中Vite和Vue-cli的特點(diǎn)與區(qū)別的相關(guān)資料,需要的朋友可以參考下2022-12-12一文教會(huì)你搭建vite項(xiàng)目并配置路由和element-plus
由于項(xiàng)目搭建過程實(shí)在繁瑣,容易遺忘,每次新建項(xiàng)目還得百度一下怎么搭建,所以寫下本文提醒自己,下面這篇文章主要給大家介紹了關(guān)于搭建vite項(xiàng)目并配置路由和element-plus的相關(guān)資料,需要的朋友可以參考下2022-07-07vue.nextTick()與setTimeout的區(qū)別及說明
這篇文章主要介紹了vue.nextTick()與setTimeout的區(qū)別及說明,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-03-03vue3插槽:el-table表頭插入tooltip及更換表格背景色方式
這篇文章主要介紹了vue3插槽:el-table表頭插入tooltip及更換表格背景色方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-06-06