繁体   English   中英

webpack 2:来自UglifyJs的./public/bundle.js中出现错误意外字符'`'

[英]webpack 2: ERROR in ./public/bundle.js from UglifyJs Unexpected character '`'

我有2个相关问题:

首先:当我运行npm run buildbundle.js文件没有缩小,但是我确实得到了bundle.js.map文件。

第二:当我运行webpack -d我只能得到一个精缩bundle.js文件(没有错误),但是当我运行webpack -p然后我得到一个bundle.js 精缩,一个bundle.js.map ,而那些错误:

ERROR in ./public/bundle.js from UglifyJs
Unexpected character '`' [./app/config.js:5,0][./public/bundle.js:76,14]

ERROR in ./public/bundle.js from UglifyJs
Unexpected character '`' [./app/config.js:5,0][./public/bundle.js:76,14]

我的问题:

  1. webpack -pwebpack -d的行为不应该相反吗?
  2. 为什么在我运行npm run build时没有缩小bundle.js
  3. 在模块中使用模板字符串时,为什么会出现那些Unexpected character错误?

package.json看起来像这样:

{
  ...,
  "scripts": {
    "build": "webpack --progress --watch"
  },
  "devDependencies": {
    "babel-core": "^6.13.2",
    "babel-loader": "^6.2.5",
    "babel-preset-es2015-native-modules": "^6.9.4",
    "eslint": "^3.3.1",
    "eslint-config-airbnb": "^10.0.1",
    "eslint-plugin-html": "^1.5.2",
    "eslint-plugin-import": "^1.13.0",
    "eslint-plugin-jsx-a11y": "^2.1.0",
    "eslint-plugin-react": "^6.1.2",
    "webpack": "^2.1.0-beta.21"
  }
}

webpack.config.js就像这样:

const webpack = require('webpack'); // eslint-disable-line import/no-extraneous-dependencies

const nodeEnv = process.env.NODE_ENV || 'production';

module.exports = {
  entry: {
    filename: './app/app.js'
  },
  output: {
    filename: './public/bundle.js'
  },
  modules: {
    loaders: [
      {
        test: /\.js?$/,
        exclude: /node_modules/,
        loader: 'babel',
        query: {
          presets: ['es2015-native-modules']
        }
      }
    ]
  },
  devtool: 'source-map',
  plugins: [
    // uglify
    new webpack.optimize.UglifyJsPlugin({
      compress: { warnings: false },
      output: { comments: false },
      sourceMap: true
    }),
    new webpack.DefinePlugin({
      'process.env': { NODE_ENV: JSON.stringify(nodeEnv) }
    })
  ]
};

我确实在这里和Google(以及webpack文档…)中都进行了搜索,但是找不到对我有用的东西。 谢谢!!

UglifyJS2的发行版中尚不支持ES6 / Harmony。 但是,有一个Harmony分支,它允许您使用ES6语法最小化/丑化文件。

我可以建议您使用另一种解决方案,该解决方案可以帮助您花费更少的构建时间将所有ES6移植到ES5。

只需在package.json中指定UglifyJs,然后让npm处理依赖项。 "uglify-js": "git://github.com/mishoo/UglifyJS2#harmony-v2.8.22",

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM