在 Angular 中,缓存问题可以通过添加版本号或修改 URL 来解决。下面是一些示例代码来解决 Angular 14 缓存突破问题:
在 Angular 的构建配置文件(通常是 angular.json 文件)中,找到 "assets" 部分,为每个静态资源文件添加一个版本号。这样当文件内容发生更改时,版本号也会变化,从而避免浏览器缓存。
"assets": [
{
"glob": "favicon.ico",
"input": "src",
"output": "./",
"version": "1.0" // 添加版本号
},
{
"glob": "**/*",
"input": "src/assets",
"output": "./assets",
"version": "1.0" // 添加版本号
}
]
在加载静态资源时,可以通过修改 URL 来防止缓存。
import { HttpClient } from '@angular/common/http';
constructor(private http: HttpClient) {}
getData() {
const url = 'api/data?cache=' + new Date().getTime(); // 添加时间戳作为参数
return this.http.get(url);
}
这样,每次请求数据时,URL 都会有一个新的时间戳参数,从而避免浏览器缓存。
可以使用 Angular 的 HttpInterceptor 来拦截请求,并在请求头中添加不缓存的标识,例如 "Cache-Control" 或 "Pragma"。
import { Injectable } from '@angular/core';
import { HttpInterceptor, HttpRequest, HttpHandler, HttpEvent } from '@angular/common/http';
import { Observable } from 'rxjs';
@Injectable()
export class NoCacheInterceptor implements HttpInterceptor {
intercept(request: HttpRequest, next: HttpHandler): Observable> {
request = request.clone({
setHeaders: {
'Cache-Control': 'no-cache',
'Pragma': 'no-cache'
}
});
return next.handle(request);
}
}
然后,在 AppModule 中添加 NoCacheInterceptor:
import { NgModule } from '@angular/core';
import { HttpClientModule, HTTP_INTERCEPTORS } from '@angular/common/http';
import { NoCacheInterceptor } from './no-cache.interceptor';
@NgModule({
imports: [HttpClientModule],
providers: [
{
provide: HTTP_INTERCEPTORS,
useClass: NoCacheInterceptor,
multi: true
}
]
})
export class AppModule {}
通过以上解决方法,可以避免 Angular 14 缓存突破问题。