最近研究webpack配置神煩,打包工具指不定哪天又要被取代。要想本身手動搭一個複雜應用的webpack腳手架不是一件容易的事, 看看vue-cli的webpack配置文件就有8+個,使用的插件有14+個,代碼800行+。還沒開始寫代碼就要搞懂這麼多「規則」,還不如多花點時間研究js核心,哪天能夠本身倒騰工具。爲了重複踩坑,仍是記錄下來適應這些規則的過程,一般工具文檔一般不會涵蓋這些內容。不作工具構建工程師,但要利用工具。html
安裝node,前往官網,node自帶npm。安裝完成打開cmd輸入下面的指令檢查是否安裝成功:vue
node -v
npm -v
複製代碼
node
指令沒反應解決:刪除npm
目錄中的npmrc
文件。node
運行npm init
根據提示初始化一個項目,生成package.json
文件webpack
注意:項目根目錄的文件夾名稱不能使用空格,不然項目會報錯。git
npm
指令沒反應解決:刪除npm
目錄中的npmrc
文件。github
解決: 注意把nodePATH
改在有權限的地方,不然後續使用命令行全局安裝包可能會有權限問題。web
npm config get prefix
node_global
和 node_cache
2個文件夾npm config set prefix
'C:\Users\Administrator\node\node_global' npm config set cache
'C:\Users\Administrator\node\node_cache'vue-cli
NODE PATH
和 PATH
中添加: C:\Users\Administrator\node\node_globalPATH
中添加: C:\Users\Administrator\node\node_global解決:刪除pakage.json.lock文件。npm
建議安裝yarn
利於版本控制,安裝 yarn官方文檔。安裝使用指令:json
yarn init // 初始化項目,生成yarn.lock文件
yarn add [pakeage] --dev // --dev 只在開發環境下使用的插件
yarn (install) // 安裝lock文件中全部的依賴
複製代碼
yarn
, 運行yarn install
報錯沒法使用!解決:把yarn
安裝文件夾下的bin
文件夾加到環境變量。
cnpm
,npm國內鏡像 (可選)npm install -g cnpm --registry=https://registry.npm.taobao.org
npm install -g vue-cli
;vue -V
;vue init webpack my-project
;night watch
,裏面的demo依賴google
的資源,國內沒法使用,啓動項目會報錯, 官網說明:The test below navigates to google.com and searches for "rembrandt van rijn", then verifies if the term first result is the Wikipedia page of Rembrandt。安裝webpack, npm install --save-dev webpack
配置webpack.config.js
文件
const path = require('path');
module.exports = {
entry: './src/app.js',(主文件本身定義)
output: {
path: path.resolve(__dirname, 'bin'),
filename: 'app.bundle.js'
}
};
複製代碼
配置本地服務 安裝客戶端服務器 npm install webpack-dev-server
;
項目啓動 webpack-dev-server --content-base build/
;
僅在開發環境使用的包:--save-dev npm install --save-dev 包名
生產環境也要使用的包: --save npm install --save 包名
要安裝babel-polyfill的緣由,官網解釋:Babel僅僅編譯了ES6的語法例如箭頭函數,使用babel-polyfill能夠編譯一些全局變量如Promise以及一些原生新特性如String.padStar。 Since Babel only transforms syntax (like arrow functions), you can use babel-polyfill in order to support new globals such as Promise or new native methods like String.padStart (left-pad). It uses core-js and regenerator. Check out our babel-polyfill docs for more info.
{
"presets": [["env",]
}
複製代碼
proxytable
在開發環境中,經過設置地址映射將複雜的url簡化,還能夠解決跨域問題
// config/index.js
proxyTable: {
'/api': { //將請求路徑中包含api所有轉發到下面配置的target路徑中
target: 'http://127.0.0.1:3000', // 你接口的域名或ip
// secure: false, // 若是是https接口,須要配置這個參數
changeOrigin: true, // 若是接口跨域,須要進行這個參數配置
pathRewrite: {
'^/api': ''
}
}},
複製代碼
let devUrl = 'api/asset/'; //與上面proxytable中配置的api路徑匹配
let proUrl = 'https://node.xxxx.com/asset/';
(curEnv == "production") ? (baseUrl = proUrl) :( baseUrl = devUrl);
複製代碼
使用vue-cli
構建的項目,在 默認狀況下 ,執行npm run build
會將全部的js代碼打包爲一個總體, 打包位置是 dist/static/js/app.[contenthash].js ,這個文件是很是大,可能好幾兆,嚴重影響頁面性能。
在路由文件中引入模塊時分模塊打包,把咱們想要組合在一塊兒的組件打包到一個chunk塊
中去,使用webpack的 require.ensure
,而且在最後加入一個chunk
名,相同chunk
名字的模塊將會打包到一塊兒。
router/index.js
const lotteryIndex = r => require.ensure([], () => r(require('@/pages/lottery/lottery-index.vue')), 'chunk1')
const drawList = r => require.ensure([], () => r(require('@/pages/lottery/draw-list.vue')), 'chunk2')
const drawDetail = r => require.ensure([], () => r(require('@/pages/lottery/draw-detail.vue')), 'chunk3')
複製代碼