15

我正在尝试将服务人员添加到我们现有的 Angular(5.2,CLI 1.7.1)应用程序中。我做了我应该做的一切:

  1. 我创建了ngsw-config.json
  2. 我运行ng set apps.0.serviceWorker=true命令,所以我有"serviceWorker": true,angular -cli.json
  3. 我已经安装"@angular/service-worker": "5.2.9"
  4. 我添加到app.module.ts

    import { ServiceWorkerModule } from '@angular/service-worker';
    imports: [
        ...
        ServiceWorkerModule.register('/ngsw-worker.js', 
            { enabled: environment.production }),
    ]
    

我什至尝试将这段代码(我在某处找到作为解决方案)添加到 main.ts

platformBrowserDynamic().bootstrapModule(AppModule).then(() => {
    if ('serviceWorker' in navigator && environment.production) {
        navigator.serviceWorker.register('/ngsw-worker.js');
    }
}).catch(err => console.log(err));

但我得到了这个错误:

Uncaught (in promise) DOMException: Failed to register a ServiceWorker: 该脚本具有不受支持的 MIME 类型 ('text/html')。

ERROR 错误:未捕获(承诺):SecurityError:无法注册 ServiceWorker:脚本具有不受支持的 MIME 类型('text/html')。在 resolvePromise (polyfills.3e9ea997ddae46e16c09.bundle.js:1)

在我自己的个人小应用程序中,我做了同样的事情,并且没有任何错误。我们遇到此错误的应用程序非常庞大。有很多第三方库。我读过他们可能有问题。

你能帮我吗?

此外,我正在检查自己的应用程序以查找可能的差异,但我没有查看 devtools 中的网络选项卡,我注意到应该由服务工作者缓存的文件总是被加载。请问这是正确的行为吗?

4

2 回答 2

20

这可能是由于缺少 ngsw-worker.js 文件造成的。

您可能正在使用HTML5 pushState 样式的 URL,并且您已将Web 服务器配置为返回服务器上实际不存在的任何文件或文件夹的索引页面(通常为 index.html)。如果 ngsw-worker.js 实际不存在,Web 服务器会将请求重定向到 ngsw-worker.js 到 index.html(因此 MIME 类型为“text/html”)。

ngsw-worker.js 文件通常会在您运行时复制到您的 dist 文件夹

ng build --prod
于 2018-03-28T20:45:45.977 回答
1

在用 Angular8 尝试了很多不同的东西之后,我终于将 angular-devkit 从 0.800.2 升级到了 0.803.2

npm install @angular-devkit/build-angular@latest

然后我得到一个错误:

错误:应在 [PROJECT] 文件夹中找到 ngsw-config.json 配置文件。在 angular.json 配置文件中提供一个或禁用 Service Worker。

我通过改变来解决这个问题

"ngswConfigPath": "ngsw-config.json""ngswConfigPath": "src/ngsw-config.json"

然后它终于奏效了。

于 2019-09-01T22:39:43.360 回答