# 特定的錯誤 node
ERROR in statics/mobile/js/vendor.cef13a0e680a5bc0d8b3.js from UglifyJs
Unexpected token: punc (() [D:/Users/Administrator/Desktop/WTFpolice/newPolice/~/mint-ui/src/utils/clickoutside.js:12,0][statics/mobile/js/vendor.cef13a0e680a5bc0d8b3.js:43784,6]webpack
通過一頓 stackoverflow以後 發現這麼幾點問題es6
1.沒有配置babel web
2.UglifyJs插件不支持es6chrome
我針對這些答案都嘗試了一遍最後得出以下方案npm
問題1的解決bash
若是是沒有配置babel 也是有可能的由於若是你在chrome下開發不裝babel 也是能夠跑得順暢的由於chrome對es6的支持是很好的babel
# 安裝babel 的依賴 npm install babel-loader babel-core babel-preset-env babel-preset-stage-2 -D
以上依次是babel的轉換器,核心庫,預處理和預處理的es6版本app
而後須要在根目錄創建一個.babelrc的文件 配置以下ide
{ "presets": [ ["env", { "modules": false, "targets": { "browsers": ["> 1%", "last 2 versions", "not ie <= 8"] } }], "stage-2" ], }
但不少狀況下咱們都是配置了,那麼咱們來看問題2
若是是UglifyJs插件不支持處理es6 官網有對應支持es6的版本,不過咱們不是爲了壓縮es6
修改webpack.base.conf配置
function resolve (dir) { return path.join(__dirname, '..', dir) } # 修改前 { test: /\.js$/, loader: 'babel-loader', include: [resolve('src'), resolve('test')] } # 修改後 { test: /\.js$/, loader: 'babel-loader', include: [resolve('src'), resolve('test'),resolve('node_modules/mint-ui/scr/utils')] }
若是你選擇更新UglifyJs插件能夠配合安裝babel-polyfill , babel-polyfill能夠模擬ES6使用的環境,能夠使用ES6的全部新方法
# 安裝 npm install -save babel-polyfill # 修改在webpack.config.js配置 # 修改前 module.exports = { entry: { app: "./src/main.js" } }; # 修改後 module.exports = { entry: { app: ["babel-polyfill", "./src/main.js"] } };