javascript - 在 Service Worker 中预缓存生成的 Assets

标签 javascript aem service-worker offline-caching

我有一些资源是在运行时或构建时生成的,例如脚本、CSS 等。
文件格式类似于 main.min.63716273681.js,其他资源也类似。

不幸的是,我无法使用 sw-precache 库或与我的构建集成的任何东西。

我如何预缓存这些资源,是否可以使用正则表达式来实现?

注意:问题是关于预缓存资源和资源是由 AEM(Adobe 体验管理器)生成的

最佳答案

安装 webpack-manifest-plugin 并在你的 webpack 配置文件的顶部导入

const ManifestPlugin = require('webpack-manifest-plugin');

在你的 webpack 插件部分使用下面的代码,这将生成一个名为 asset-manifest.json 的文件,其中包含由 webpack 构建的所有 Assets

new ManifestPlugin({
        fileName: 'asset-manifest.json',
        publicPath: your public path here,
 }),

它会生成如下内容的文件

// Assets list .json

{
  "files": {
    "about.js": "/static/js/about.bc816d03.chunk.js",
    "about.js.map": "/static/js/about.bc816d03.chunk.js.map",
    "dashboard.js": "/static/js/dashboard.f180c270.chunk.js",
    "dashboard.js.map": "/static/js/dashboard.f180c270.chunk.js.map",
    "homepage.js": "/static/js/homepage.4dd0316c.chunk.js",
    "homepage.js.map": "/static/js/homepage.4dd0316c.chunk.js.map",
    "login.js": "/static/js/login.1b8cf466.chunk.js",
    "login.js.map": "/static/js/login.1b8cf466.chunk.js.map",
    "logout.js": "/static/js/logout.ac3c5758.chunk.js",
    "logout.js.map": "/static/js/logout.ac3c5758.chunk.js.map",
    "main.css": "/static/css/main.977b6895.chunk.css",
    "main.js": "/static/js/main.a65a1d5d.chunk.js",
    "main.js.map": "/static/js/main.a65a1d5d.chunk.js.map",
    "profile.js": "/static/js/profile.20ae3dae.chunk.js",
    "profile.js.map": "/static/js/profile.20ae3dae.chunk.js.map",
    "runtime-main.js": "/static/js/runtime-main.ad8b0a50.js",
    "runtime-main.js.map": "/static/js/runtime-main.ad8b0a50.js.map",
    "static/js/8.796ce7e3.chunk.js": "/static/js/8.796ce7e3.chunk.js",
    "static/js/8.796ce7e3.chunk.js.map": "/static/js/8.796ce7e3.chunk.js.map",
    "index.html": "/index.html",
    "precache-manifest.e770a629726af82e25b547dd941bae89.js": "/precache-manifest.e770a629726af82e25b547dd941bae89.js",
    "service-worker.js": "/service-worker.js",
    "static/css/main.977b6895.chunk.css.map": "/static/css/main.977b6895.chunk.css.map",
    "static/js/8.796ce7e3.chunk.js.LICENSE.txt": "/static/js/8.796ce7e3.chunk.js.LICENSE.txt",
    "static/media/arvidsson.jpg": "/static/media/arvidsson.4d6f8e0d.jpg",
    "static/media/logo.jpg": "/static/media/logo.8caa15b8.jpg",
    "static/media/pekka.jpg": "/static/media/pekka.1eab475c.jpg"
  },
  "entrypoints": [
    "static/js/runtime-main.ad8b0a50.js",
    "static/js/8.796ce7e3.chunk.js",
    "static/css/main.977b6895.chunk.css",
    "static/js/main.a65a1d5d.chunk.js"
  ]
}

您可以阅读 asset-manifest.json 文件并获取文件对象并迭代并检查最后具有 .js 的 key 。

希望这能回答您的问题。

关于javascript - 在 Service Worker 中预缓存生成的 Assets ,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/61723957/

相关文章:

java - OSGi bundle - 获取 DataSourcePool 以在 Adob​​e CQ5 中的 servlet 中使用

java - JCR SQL2 查询 : binding of ISDESCENDANTNODE param

AEM/CQ5 如何共享组件值?

javascript - 如何使用 Service Worker 从一开始就处理获取事件?

javascript - 当 Assets 发生变化时更新 service worker

javascript - 服务 worker - 最简单的实现

javascript - react 警告 Expected to return a value at the end of arrow function array-callback-return

javascript - 如何解析GAS中的姓名和电子邮件

javascript - 我怎样才能将数据添加到firebase数据库中

javascript - 防止整页在 load() 时向上滚动