[next.js]pwa缓存

配置Next.js (v14+ App Router模式) 使其支持PWA缓存,配置server worker和mainfest.json,让项目支持离线访问和可安装。

安装依赖next-pwa

npm i next-pwa

配置next.config.js

const path = require('path');

const withPWAInit = require('next-pwa');

// 判断环境
const isProd = ['production'].includes(process.env.NODE_ENV);

/** @type {import('next-pwa').PWAConfig} */
const withPWA = withPWAInit({
  dest: 'public',
  disable: !isProd,
  // Solution: https://github.com/shadowwalker/next-pwa/issues/424#issuecomment-1399683017
  buildExcludes: ['app-build-manifest.json'],
});

const generateAppDirEntry = (entry) => {
  const packagePath = require.resolve('next-pwa');
  const packageDirectory = path.dirname(packagePath);
  const registerJs = path.join(packageDirectory, 'register.js');

  return entry().then((entries) => {
    // Register SW on App directory, solution: https://github.com/shadowwalker/next-pwa/pull/427
    if (entries['main-app'] && !entries['main-app'].includes(registerJs)) {
      if (Array.isArray(entries['main-app'])) {
        entries['main-app'].unshift(registerJs);
      } else if (typeof entries['main-app'] === 'string') {
        entries['main-app'] = [registerJs, entries['main-app']];
      }
    }
    return entries;
  });
};

/** @type {import('next').NextConfig} */
const nextConfig = {
	// ... 你的next.config配置项
	...
	webpack: (config) => {
    	const entry = generateAppDirEntry(config.entry);
   	 	config.entry = () => entry;
    	return config;
  	},
}

module.exports = withPWA(nextConfig);

以上配置 我让其在生产环境自动创建server worker和workbox等文件并在浏览器加载时初始化init sw文件,第二次访问时便可以创建sw缓存
在这里插入图片描述
在这里插入图片描述

相关推荐

  1. 缓存

    2024-06-08 20:06:04       65 阅读
  2. 缓存缓存缓存

    2024-06-08 20:06:04       32 阅读
  3. Buffer(缓冲)、Cache(缓存

    2024-06-08 20:06:04       63 阅读
  4. 缓存缓存简介

    2024-06-08 20:06:04       35 阅读
  5. Redis缓存击穿、缓存雪崩、缓存穿透

    2024-06-08 20:06:04       56 阅读
  6. http缓存?强制缓存和协商缓存

    2024-06-08 20:06:04       46 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-06-08 20:06:04       98 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-06-08 20:06:04       106 阅读
  3. 在Django里面运行非项目文件

    2024-06-08 20:06:04       87 阅读
  4. Python语言-面向对象

    2024-06-08 20:06:04       96 阅读

热门阅读

  1. 零基础入门学习Python第二阶05MySQL详解01

    2024-06-08 20:06:04       37 阅读
  2. 360数字安全:2024年1月勒索软件流行态势分析报告

    2024-06-08 20:06:04       31 阅读
  3. 【名词解释】Unity中的Toggle组件及其使用示例

    2024-06-08 20:06:04       30 阅读
  4. mac m1使用docker安装mysql5.7,并且开启binlog

    2024-06-08 20:06:04       29 阅读
  5. 代码随想录35期总结

    2024-06-08 20:06:04       41 阅读
  6. break、continue、return

    2024-06-08 20:06:04       32 阅读
  7. nginx location正则表达式+案例解析

    2024-06-08 20:06:04       39 阅读
  8. 设计模式-外观模式

    2024-06-08 20:06:04       34 阅读