1.先安裝vue-cli3.0(按官方文檔走一邊):cli.vuejs.org/zh/guide/in…css
2.建立項目:html
a.手動建立:vue create my-project
vue
cli.vuejs.org/zh/guide/cr…node
手動建立,更具需求添加你須要的選項
webpack
b.經過 vue ui
命令以圖形化界面建立和管理項目(推薦)
ios
1).選擇項目目錄,填寫項目所在文件夾名稱,包管理器有npm、yarn。
nginx
2).默認狀況下不少細節沒法知曉,故,初次使用建議選擇手動
配置項目c++
3).在功能這塊,選你可能須要的便可,後面也能夠刪除或添加
git
4).路由模式、css預設處理器、編碼格式規則、測試等等設置(後期均可以改)
。
es6
5).設置項目名稱,若有須要能夠保持該項目的全部預設配置,方便下次建立同類型項目能夠直接選擇相同配置
3.建立成功接下來就要配置咱們的vue.config.js(配置以下)
:
/**
* *@2018-10-08
* *@author trsoliu
* *@describe vue-cli 3.x配置文件
*/
const path = require('path');
const vConsolePlugin = require('vconsole-webpack-plugin'); // 引入 移動端模擬開發者工具 插件 (另:https://github.com/liriliri/eruda)
const CompressionPlugin = require('compression-webpack-plugin'); //Gzip
const BundleAnalyzerPlugin = require('webpack-bundle-analyzer').BundleAnalyzerPlugin; //Webpack包文件分析器
const baseUrl = process.env.NODE_ENV === "production" ? "/static/" : "/"; //font scss資源路徑 不一樣環境切換控制
module.exports = {
//基本路徑
//baseUrl: './',//vue-cli3.3如下版本使用
publicPath:'./',//vue-cli3.3+新版本使用
//輸出文件目錄
outputDir: 'mcdonalds',
// eslint-loader 是否在保存的時候檢查
lintOnSave: true,
//放置生成的靜態資源 (js、css、img、fonts) 的 (相對於 outputDir 的) 目錄。
assetsDir: 'static',
//以多頁模式構建應用程序。
pages: undefined,
//是否使用包含運行時編譯器的 Vue 構建版本
runtimeCompiler: false,
//是否爲 Babel 或 TypeScript 使用 thread-loader。該選項在系統的 CPU 有多於一個內核時自動啓用,僅做用於生產構建,在適當的時候開啓幾個子進程去併發的執行壓縮
parallel: require('os').cpus().length > 1,
//生產環境是否生成 sourceMap 文件,通常狀況不建議打開
productionSourceMap: false,
// webpack配置
//對內部的 webpack 配置進行更細粒度的修改 https://github.com/neutrinojs/webpack-chain see https://github.com/vuejs/vue-cli/blob/dev/docs/webpack.md
chainWebpack: config => {
/**
* 刪除懶加載模塊的prefetch,下降帶寬壓力
* https://cli.vuejs.org/zh/guide/html-and-static-assets.html#prefetch
* 並且預渲染時生成的prefetch標籤是modern版本的,低版本瀏覽器是不須要的
*/
//config.plugins.delete('prefetch');
//if(process.env.NODE_ENV === 'production') { // 爲生產環境修改配置...process.env.NODE_ENV !== 'development'
//} else {// 爲開發環境修改配置...
//}
},
//調整 webpack 配置 https://cli.vuejs.org/zh/guide/webpack.html#%E7%AE%80%E5%8D%95%E7%9A%84%E9%85%8D%E7%BD%AE%E6%96%B9%E5%BC%8F
configureWebpack: config => {
//生產and測試環境
let pluginsPro = [
new CompressionPlugin({ //文件開啓Gzip,也能夠經過服務端(如:nginx)(https://github.com/webpack-contrib/compression-webpack-plugin)
filename: '[path].gz[query]',
algorithm: 'gzip',
test: new RegExp('\\.(' + ['js', 'css'].join('|') + ')$', ),
threshold: 8192,
minRatio: 0.8,
}),
// Webpack包文件分析器(https://github.com/webpack-contrib/webpack-bundle-analyzer)
new BundleAnalyzerPlugin(),
];
//開發環境
let pluginsDev = [
//移動端模擬開發者工具(https://github.com/diamont1001/vconsole-webpack-plugin https://github.com/Tencent/vConsole)
new vConsolePlugin({
filter: [], // 須要過濾的入口文件
enable: true // 發佈代碼前記得改回 false
}),
];
if(process.env.NODE_ENV === 'production') { // 爲生產環境修改配置...process.env.NODE_ENV !== 'development'
config.plugins = [...config.plugins, ...pluginsPro];
} else {
// 爲開發環境修改配置...
config.plugins = [...config.plugins, ...pluginsDev];
}
},
css: {
// 啓用 CSS modules
modules: false,
// 是否使用css分離插件
extract: true,
// 開啓 CSS source maps,通常不建議開啓
sourceMap: false,
// css預設器配置項
loaderOptions: {
sass: {
//設置css中引用文件的路徑,引入通用使用的scss文件(如包含的@mixin)
data: `
$baseUrl: "/";
@import '@/assets/scss/_common.scss';
`
//data: `
//$baseUrl: "/";
//`
}
}
},
// webpack-dev-server 相關配置 https://webpack.js.org/configuration/dev-server/
devServer: {
// host: 'localhost',
host: "0.0.0.0",
port: 8000, // 端口號
https: false, // https:{type:Boolean}
open: true, //配置自動啓動瀏覽器 http://172.11.11.22:8888/rest/XX/
hotOnly: true, // 熱更新
// proxy: 'http://localhost:8000' // 配置跨域處理,只有一個代理
proxy: { //配置自動啓動瀏覽器
"/XX/*": {
target: "http://172.11.11.11:7071",
changeOrigin: true,
// ws: true,//websocket支持
secure: false
},
"/XX2/*": {
target: "http://172.12.12.12:2018",
changeOrigin: true,
//ws: true,//websocket支持
secure: false
},
}
},
// 第三方插件配置 https://www.npmjs.com/package/vue-cli-plugin-style-resources-loader
pluginOptions: {
'style-resources-loader': {//https://github.com/yenshih/style-resources-loader
preProcessor: 'scss',//聲明類型
'patterns': [
//path.resolve(__dirname, './src/assets/scss/_common.scss'),
],
//injector: 'append'
}
}
};複製代碼
4.同時爲了保證ES版本的兼容,咱們還須要配置一下babel.config.js
//babel.config.js
module.exports = {
presets: [
[
"@vue/app",
{
polyfills: ["es6.promise", "es6.symbol"]
}
]
]
};
複製代碼
5.瀏覽器css兼容處理文件.browserslistrc
以及.postcssrc.js
//.browserslistrc
> 1%
last 2 versions
not ie <= 8
複製代碼
//.postcssrc.js
module.exports = {
plugins: {
autoprefixer: {},
//'postcss-px2rem': {
// remUnit: 75,
//},
'postcss-px2rem-exclude': {
remUnit: 75,
exclude: /node_modules|assets|login|main/gi,
},
}
};複製代碼
6..eslintrc.js
的配置能夠直接在圖形化界面配置
module.exports = {
root: true,
env: {
node: true
},
extends: ["plugin:vue/essential", "@vue/prettier"],
rules: {
"no-console": process.env.NODE_ENV === "production" ? "error" : "off",
"no-debugger": process.env.NODE_ENV === "production" ? "error" : "off"
},
parserOptions: {
parser: "babel-eslint"
}
};複製代碼
這個配置我會更具項目持續更新,有建議或問題能夠加羣qq交流535798405
隨便再給個基於這個配置的一個demo:https://github.com/trsoliu/vue-cli3.x-configure