如何在React构建中禁用Uglify

12

我尝试使用 Y.js(Yjs)npm 包,它在 npm start 中可用,但在 npm run build 中不可用,因为 Uglify 不支持 ES6。所以我下载了该包的发布版本,并直接包含它。但我的 ReactJS npm run build 仍然抱怨 Uglify。

Creating an optimized production build...
Failed to compile.

static/js/main.3d2ecf94.js from UglifyJs
SyntaxError: Unexpected token: name (YArray) [./src/Pages/Collaborative/y-array/y-array.es6:12,0]

我的webpack.config.js看起来像这样:

var path = require('path');

module.exports = {
  entry: path.join(__dirname, 'public', 'quickstart.js'),
  output: {
    path: '/',
    filename: 'bundle.js'
  },
  module: {
    loaders: [
      {
        test: /.jsx?$/,
        loader: 'babel-loader',
        exclude: /node_modules/,
        query: {
          presets: ["react", "es2016", "stage-2"]
        }
      },
      { test: /\.css$/, loader: "style-loader!css-loader" }
    ]
  }
}

如何在webpack中禁用Uglify?哪一行确定了构建过程中需要进行Uglify的设置?

编辑:

{
  "name": "myCoolApps",
  "version": "0.1.0",
  "private": true,
  "devDependencies": {
    "css-loader": "^0.26.1",
    "react-scripts": "0.7.0",
    "webpack": "^1.13.3"
  },
  "dependencies": {
    "ace": "git+https://github.com/ajaxorg/ace.git#master",
    "antd": "^2.7.2",
    "axios": "^0.15.3",
    "card": "^2.2.1",
    "card-react": "^1.2.6",
    "chat-template": "0.0.22",
    "codemirror": "^5.25.0",
    "credit-card-type": "^5.0.1",
    "css-loader": "^0.26.1",
    "d3": "^4.7.4",
    "firechat": "^3.0.1",
    "firepad": "^1.4.0",
    "flux": "^3.1.0",
    "gulp": "^3.9.1",
    "gulp-sass": "^3.1.0",
    "history": "^1.17.0",
    "little-loader": "^0.2.0",
    "lodash": "^4.17.4",
    "material-ui": "^0.16.6",
    "moment": "^2.17.1",
    "node-sass": "^4.5.0",
    "quill": "^1.2.3",
    "rc-calendar": "^7.6.5",
    "react": "^15.5.4",
    "react-autosuggest": "^7.0.1",
    "react-cookie": "^1.0.4",
    "react-credit-card": "^0.20.0",
    "react-dom": "^15.5.4",
    "react-dropzone": "^3.8.0",
    "react-event-timeline": "^1.2.2",
    "react-infinite": "^0.10.0",
    "react-infinite-scroller": "^1.0.7",
    "react-list": "^0.8.3",
    "react-notification-system": "^0.2.12",
    "react-router": "^3.0.0",
    "react-tap-event-plugin": "^2.0.1",
    "seedrandom": "^2.4.2",
    "simplewebrtc": "^2.2.2",
    "style-loader": "^0.13.1",
    "superagent": "^3.3.1",
    "y-array": "^10.0.6",
    "y-indexeddb": "^8.1.9",
    "y-leveldb": "0.0.1",
    "y-map": "^10.0.5",
    "y-memory": "^8.0.8",
    "y-richtext": "^9.0.8",
    "y-text": "^9.3.2",
    "y-webrtc": "^8.0.7",
    "y-websockets-client": "^8.0.15",
    "yjs": "^12.1.7"
  },
  "scripts": {
    "start": "react-scripts start",
    "build": "react-scripts build",
    "test": "react-scripts test --env=jsdom",
    "eject": "react-scripts eject"
  }
}

实际上,我认为它使用了react-script。有什么我可以做来更改它吗?


可能是如何使用Webpack构建压缩和未压缩的代码包?的重复问题。 - Syed Ali Taqi
2
请粘贴您的 package.json 文件。您的配置文件没有设置使用 uglify。可能是 package.json 文件中的 build 脚本使用了 -p 选项运行 webpack,而 webpack 内部使用 Uglify。 - hazardous
我添加了我的 package.js,这实际上提醒我它使用的 react-script 我估计是无法控制的。那么我假设可能我的构建系统根本没有使用我的 webpack.config.js。webpack.config.js 的常见用途是什么? - Tianhao Zhou
你找到答案了吗?我也遇到了同样的问题。 - Miguel Mota
1
@MiguelMota 我最终在webpack中删除了build属性,这暂时解决了问题,但不适合生产目的。最终我弃用了Yjs并自己编写了同步功能。 - Tianhao Zhou
显示剩余6条评论
1个回答

1
如果你查看 npm run build 的操作,实际上它运行了另一个脚本 react-scripts build。你的项目是使用 create-react-app 进行初始化的,对吗?
正如在 package.json 中所示,你还可以访问一个名为 eject 的脚本。
运行 npm run eject 将允许你从预配置的工作流程 ( webpack, babel 等 ) 中移除应用程序,并让你根据自己的需要修改工作流程。
有了访问配置文件的权限,你可以添加一些插件,例如 babel uglify plugin
但要小心,这是一个折衷方案。正如文档中提到的:

如果你的项目需要更多定制化,你可以 "eject" 并进行自定义,但随后你将需要维护这个配置。


网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接