javascript - Webpack 4 和 Uglify 插件(TypeError : Cannot read property 'length' of undefined)

标签 javascript node.js webpack yarnpkg webpack-plugin

我在 Linux 机器上使用 Webpack 4 时遇到问题。该构建在开发模式下运行良好,但在生产模式下失败。它似乎也在 Windows 机器上工作。我确实尝试过将 webpack 降级到旧版本,但什么也没做。

Node : v10.2.1

 *TypeError: Cannot read property 'length' of undefined* at node_modules/uglifyjs-webpack-plugin/dist/uglify/index.js:59
        this.workers = workers === true ? _os2.default.cpus().length - 1 : Math.min(Number(workers) || 0, _os2.default.cpus().length - 1);

packge.json

{
  "name": "webpack-demo",
  "version": "1.0.0",
  "license": "MIT",
  "scripts": {
    "build": "webpack -p"
  },
  "devDependencies": {},
  "dependencies": {
    "@types/node": "^10.5.1",
    "css-loader": "^0.28.11",
    "global": "^4.3.2",
    "node-sass": "^4.9.1",
    "npm": "^6.1.0",
    "sass-loader": "^7.0.3",
    "style-loader": "^0.21.0",
    "ts-loader": "^4.4.2",
    "typescript": "^2.9.2",
    "uglifyjs-webpack-plugin": "1.0.0-beta.2",
    "webpack": "^4.15.1",
    "webpack-cli": "^3.0.8"
  }
}

webpack.config.js

const path = require('path');
const UglifyJsPlugin = require('uglifyjs-webpack-plugin');
var webpack = require('webpack');
module.exports = {
    entry: './src/index.ts',
    devtool: 'source-map',
     mode: 'production',
     module: {
             rules: [{
                 test: /\.tsx?$/,
                 use: 'ts-loader',
                 exclude: /node_modules/
             },
             {
                 test: /\.scss$/,
                 use: ['style-loader', 'css-loader', 'sass-loader'],
                 exclude: /node_modules/
             }
            ],
         },
    resolve: {
             extensions: ['.tsx', '.ts', '.js','.css','.scss']
         },
    plugins: [
        new UglifyJsPlugin()
    ],
    output: {
        path: path.resolve(__dirname, 'dist'),
        filename: 'main.js'
    }
}

最佳答案

在 Webpack v4 中将 mode 设置为 production 应该可以进行足够的优化,因此无需特别要求 Uglify 插件。尝试删除 uglifyjs-webpack-plugin 并且也不需要为 build 脚本传递 -p 标志。

如果你想自定义Uglify插件,你也可以在Webpack的optimization配置中进行,参见https://webpack.js.org/configuration/optimization/

const UglifyJsPlugin = require('uglifyjs-webpack-plugin');

module.exports = {
  //...
  optimization: {
    minimizer: [
      new UglifyJsPlugin({ /* your config */ })
    ]
  }
};

最后,我在 Github 上有了一个基本的 webpack v4 入门样板,其中包含所有最新的生态系统,take a look看看它是否对你有帮助

关于javascript - Webpack 4 和 Uglify 插件(TypeError : Cannot read property 'length' of undefined),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/51243247/

相关文章:

javascript - 我如何判断 HTML 元素是否正在屏幕上呈现?

javascript - 无法将 Prop 中的功能传递给组件 | react

node.js https没有响应 'end'事件, 'close'代替?

typescript - 如何让 WebStorm 中的 TypeScript 解析 webpack 的别名?

javascript - 找不到模块包

javascript - 将JSP文件加载到Javascript中实现Fragments

javascript - ng-disabled用在按钮中不起作用的原因是什么

node.js - 告诉 Puppeteer 打开 Chrome 选项卡而不是窗口

javascript - 加载不同的类并执行相似的函数名

javascript - 让 webpack 包含 html 文件