Angular如何防止缓存?
创始人
2024-10-29 07:00:31
0

在Angular应用程序中,可以使用以下方法防止浏览器缓存文件:

  1. 给应用之后的所有文件添加版本号(如?v=1.0.0),以便每次更改后都能强制客户端从服务器重新下载文件。可以在Angular的构建配置文件(angular.json, .angular-cli.json等)中配置输出文件名带上版本号:
"outputHashing": "all"

或者手动使用以下语法添加版本号:


  1. 让Angular服务端生成的HTML具有唯一性,以便客户端从服务器获得新页面的HTML而不是缓存的HTML。可以在app.module.ts文件中,通过指定providers为APP_INITIALIZER,以便在应用程序启动时执行:
import { NgModule, APP_INITIALIZER } from '@angular/core';
import { BrowserModule } from '@angular/platform-browser';
import { AppComponent } from './app.component';

export function initApp() {
  // 用随机数作为版本号
  const version = Math.random();
  document.cookie = `appVersion=${version}`;
}

@NgModule({
  declarations: [AppComponent],
  imports: [BrowserModule],
  providers: [
    {
      provide: APP_INITIALIZER,
      useFactory: initApp,
      multi: true
    }
  ],
  bootstrap: [AppComponent]
})
export class AppModule {}

这将在应用程序房启动时随机生成一个版本号,并以cookie的方式存储。每当重新启动应用程序时,都会生成新的版本号。

注:这种方法基于一个假设:如果HTML是唯一的,那么它的资源也应该是唯一的。

  1. 配置服务器(如Nginx)为禁用浏览器缓存,以便客户端从服务器获取更新的文件。可以将下面的代码放入服务器的配置文件中:
location / {
  //

相关内容

热门资讯

第一分钟妙计!wepoker分... 第一分钟妙计!wepoker分析(透视)其实真的是有辅助插件(哔哩哔哩)1、wepoker分析辅助软...
三分钟技法!wepoker透视... 三分钟技法!wepoker透视脚本安卓(透视)确实是真的有辅助辅助(哔哩哔哩)进入游戏-大厅左侧-新...
十分钟策略!wepoker有没... 十分钟策略!wepoker有没有插件(透视)原来存在有辅助插件(哔哩哔哩)1、实时wepoker有没...
第3分钟诀窍!德州来玩辅助器(... 第3分钟诀窍!德州来玩辅助器(透视)一贯真的有辅助插件(哔哩哔哩)1、德州来玩辅助器脚本辅助下载、德...
6分钟模板!wejoker开挂... 6分钟模板!wejoker开挂(透视)果然有辅助辅助(哔哩哔哩)一、wejoker开挂游戏安装教程牌...
八分钟经验!wepoker透视... 八分钟经验!wepoker透视脚本安卓(透视)一直真的是有辅助下载(哔哩哔哩)进入游戏-大厅左侧-新...
第1分钟窍要!hhpoker透... 第1分钟窍要!hhpoker透视脚本下载(透视)一直真的是有辅助下载(哔哩哔哩)1、第1分钟窍要!h...
第九分钟手段!wpk辅助(透视... 第九分钟手段!wpk辅助(透视)都是真的是有辅助安装(哔哩哔哩)1、第九分钟手段!wpk辅助(透视)...
第五分钟阶段!hh poker... 第五分钟阶段!hh poker透视器下载(透视)总是是真的有辅助教程(哔哩哔哩)亲,关键说明,hh ...
第五分钟指南!wepoker游... 第五分钟指南!wepoker游戏的安装教程(透视)其实真的有辅助脚本(哔哩哔哩)1、玩家可以在wep...