4

我有一个 Webpack 配置文件,它使用webpack-pwa-manifest插件 ( https://github.com/arthurbergmz/webpack-pwa-manifest ) 生成 PWA 清单文件。清单文件名为manifest.hash.json,其中“hash”是每次构建时动态生成的值。

我还使用(https://developers.google.com/web/tools/workbox/modules/workbox-webpack-pluginInjectManifest )的插件来呈现预缓存清单,然后将其注入到服务工作者文件中。Workbox

这是我的 Webpack 配置文件的“插件”部分:

      plugins: [
        new CleanWebpackPlugin([ path.join(destDir, '*.*') ], {
        allowExternal: true,
        exclude: [],
        verbose: true,
        dry: false
      }),
      new MiniCssExtractPlugin({
        filename: 'style.[hash].css'
      }),
      new VueLoaderPlugin(),
      new HtmlWebpackPlugin({
        template: path.join(projectRoot, 'src/index.html')
      }),
      new WebpackPwaManifest({
        name: 'Test PWA',
        short_name: 'Test PWA',
        fingerprints: true,
        inject: true,
        lang: 'en-US',
        start_url: 'https://localhost:8120/index.html',
        display: 'standalone',
        theme_color: '#777777',
        background_color: '#333333',
        icons: [
          {
            src: path.join(sourceDir, 'images/icon.png'),
            sizes: [36, 48, 72, 96, 144, 192, 512],
            destination: 'icons'
          }
        ]
      }),
      new InjectManifest({
        swSrc: path.join(projectRoot, 'src/sw.js'),
        swDest: 'sw.js',
        importWorkboxFrom: 'local',
        globPatterns: ['dist/*.{json,js,html}']
      })
    ]

问题是我找不到将渲染添加manifest.hash.json到 InjectManifest 生成的预缓存清单中的方法。有什么办法可以让他们一起玩得很好,还是不可能?

4

3 回答 3

2

manifest.<chunkhash>.js对于未包含在生成的预缓存清单中的名为 commons 的块,我遇到了同样的问题。

解决方案是在 webpack 配置文件中添加插件exclude选项InjectManifest,因为它的默认值是(根据docs[/\.map$/, /^manifest.*\.js(?:on)?$/]:。

plugins: [
  new InjectManifest({
    swSrc: path.join(projectRoot, 'src/sw.js'),
    swDest: 'sw.js',
    importWorkboxFrom: 'local',
    exclude: [] // <-- Add this
  })
]
于 2018-08-31T09:32:15.990 回答
1

它已在 Workbox v4.0.0 中修复:https ://github.com/GoogleChrome/workbox/pull/1679

于 2018-11-15T18:42:32.273 回答
0

不知何故,由插件生成的文件webpack-pwa-manifest不包含在 webpack 构建管道中(可能是一个错误),因此InjectManifest插件无法即时添加所有资产。

有一种解决方法可以使用globDirectoryglobPatterns选项预缓存其他资产:

new InjectManifest({
  swSrc: './dist/sw.js',
  globDirectory: '.',
  globPatterns: ['dist/manifest.*.json']
})

在此配置示例中,插件获取所有捆绑包和您的附加清单文件作为外部文件。但是 webpack 给你一个警告:

您正在使用以下 Workbox 配置选项:[globDirectory, globPatterns]。在 Workbox v3 及更高版本中,通常不需要这样做。

你应该只将它用于那些不是由 webpack 执行的资产。检查文档中的解释。

在您的特定配置中,问题是您错过了globDirectory: '.'选项并且插件找不到文件。

我希望它仍然相关并且对您有所帮助。

于 2018-07-18T12:46:14.100 回答