使用“prod”标志构建后,Angular应用程序不会被uglified

问题描述 投票:1回答:2

我正在运行Angular 7.我对production构建的设置包含密钥optimization=truebuildOptimizer=true。我将在底部包含一大块完整的production配置部分我的angular.json文件。

我在AWS Amplify上运行自动构建。我还将在底部包含构建配置,但基本上它运行npm run build --prod

问题是,在构建成功后,我可以导航到我的Web应用程序,仍然可以看到所有源代码都未经过验证(通过访问Chrome开发人员控制台并查看webpack目录的内容)。无法确定我做错了什么。

angular.json

"production": {
  "fileReplacements": [
    {
      "replace": "src/environments/environment.ts",
      "with": "src/environments/environment.prod.ts"
    }
  ],
  "optimization": true,
  "outputHashing": "all",
  "sourceMap": false,
  "extractCss": true,
  "namedChunks": false,
  "aot": true,
  "extractLicenses": true,
  "vendorChunk": false,
  "buildOptimizer": true,
  "budgets": [
    {
      "type": "initial",
      "maximumWarning": "2mb",
      "maximumError": "5mb"
    }
  ],
  "serviceWorker": true
}

构建脚本:

version: 0.1
frontend:
  phases:
    preBuild:
      commands:
        - npm ci
    build:
      commands:
        - npm run build --prod
  artifacts:
    baseDirectory: dist/myprojectname
    files:
      - '**/*'
  cache:
    paths:
      - node_modules/**/*
angular amazon-web-services npm web-applications aws-amplify
2个回答
1
投票

为什么不使用Angular-CLI?

只是命令

构建--prod

我认为你的'npm run build --prod'是自定义命令。所以,prod标志是未定义的。不是吗?


1
投票

如果您使用的是webpack,请尝试使用devtool选项devtool: "hidden-source-map"作为解决方法。

© www.soinside.com 2019 - 2024. All rights reserved.