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 / {
  //

相关内容

热门资讯

透视工具"欢乐卡五星... 透视工具"欢乐卡五星辅助工具"开挂(神器)辅助神器有挂总结-教你攻略这是一款可以让一直输的玩家,快速...
一分钟教会你"来玩a... 一分钟教会你"来玩app辅助器"开挂(插件)辅助插件有挂透明挂-透明挂教程;亲,来玩app辅助器这款...
今日重大通报"潮友会... 您好:这款潮友会插件游戏是可以开挂的,确实是有挂的,很多玩家在这款潮友会插件游戏中打牌都会发现很多用...
一分钟了解"花花生活... 一分钟了解"花花生活圈第三方工具"开挂(插件)辅助插件有挂规律-可靠教程《详细加薇136704302...
玩家必看"老友广西玩... 玩家必看"老友广西玩有破解视频"开挂(工具)辅助工具竟然有挂-插件教程;打开点击测试直接进入微信(1...
让我来分享经验"we... 较多好评“微乐万能挂官网”开挂(透视)辅助教程 了解更多开挂安装加(136704302)微信号是一款...
热点推荐"神兽互娱辅... 热点推荐"神兽互娱辅助免费"开挂(下载)辅助下载有挂方针-解密教程;无需打开直接搜索薇:136704...
透视美元局"闲娱江西... 闲娱江西打盾插件是一款可以让一直输的玩家,快速成为一个“必胜”的ai辅助神器,有需要的用户可以加我微...
一起来讨论"贵州闲来... 一起来讨论"贵州闲来辅助工具"开挂(平台)辅助平台有挂助手-黑科技教程;打开点击测试直接进入微信(1...
揭秘攻略"财神十三张... 揭秘攻略"财神十三张安装工具"开挂(插件)辅助插件了解有挂-高科技教程;无需打开直接搜索薇:1367...