angular 缓存 html5,Angular 如何及时更新客户端缓存?

如果你是

Angular 新手

或者对 Http 缓存机制理解不清晰

使用 Angular CLI 开发 Angular

请继续往下读。

背景

在 Angular 开发的过程中, 我们经常会发布新的功能或者 fix bug,但是由于浏览器缓存的存在, 可能用户打开的页面并不是最新发布的。 而我们想要的是用户既可以及时看到我们的更新, 又可以在我们没有更新软件时使用缓存中的资源。

解决办法

往往静态资源由 Nginx、apache、IIS 等提供, 我们以 Nginx(当前最新版本是 1.15.8, 请确保 Nginx 版本不低于 1.7.3 changelog) 为例,简单说来就是:

在 Nginx 配置文件 nginx.conf 中确保 Etag 开启(默认是开启的)

对 index.html 设置响应缓存头:

Cache-Control: no-cache

客户端每次请求 index.html 时都要重新验证 index.html 是否发生了改变,

如果发生了改变,就会请求新的 index.html。

css、js 文件中都有 fingerprint,比如, style.x234dff.css.

css、js 文件改变 => fingerprint 改变 => 文件名改变 => index.html 改变 => 浏览器下载新的 index.html => 浏览器请求新的 css、js 文件。

对 css、js、图片等文件设置响应缓存头:

Cache-Control: max-age=31536000 // 缓存一年。

由于 css、js 文件名里有

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Angular中,可以使用FormGroup和FormControl来管理表单数据,也可以通过使用本地存储(localStorage)来缓存表单数据。 以下是一个简单的例子,可以将表单数据存储在本地存储中: 1. 在表单组件中,定义一个FormGroup对象,并将其初始化为存储在本地存储中的值(如果存在): ``` import { Component } from '@angular/core'; import { FormGroup, FormControl } from '@angular/forms'; @Component({ selector: 'app-form', templateUrl: './form.component.html', styleUrls: ['./form.component.css'] }) export class FormComponent { form: FormGroup; constructor() { this.form = new FormGroup({ name: new FormControl(localStorage.getItem('name')), email: new FormControl(localStorage.getItem('email')), phone: new FormControl(localStorage.getItem('phone')) }); } onSubmit() { // Save form data to local storage localStorage.setItem('name', this.form.value.name); localStorage.setItem('email', this.form.value.email); localStorage.setItem('phone', this.form.value.phone); // Submit form data to server // ... } } ``` 2. 在表单提交时,将表单数据存储在本地存储中: ``` onSubmit() { // Save form data to local storage localStorage.setItem('name', this.form.value.name); localStorage.setItem('email', this.form.value.email); localStorage.setItem('phone', this.form.value.phone); // Submit form data to server // ... } ``` 3. 在表单组件中添加一个ngOnDestroy钩子函数,以确保在组件销毁时清除本地存储中的表单数据: ``` import { Component, OnDestroy } from '@angular/core'; import { FormGroup, FormControl } from '@angular/forms'; @Component({ selector: 'app-form', templateUrl: './form.component.html', styleUrls: ['./form.component.css'] }) export class FormComponent implements OnDestroy { form: FormGroup; constructor() { this.form = new FormGroup({ name: new FormControl(localStorage.getItem('name')), email: new FormControl(localStorage.getItem('email')), phone: new FormControl(localStorage.getItem('phone')) }); } onSubmit() { // Save form data to local storage localStorage.setItem('name', this.form.value.name); localStorage.setItem('email', this.form.value.email); localStorage.setItem('phone', this.form.value.phone); // Submit form data to server // ... } ngOnDestroy() { // Clear form data from local storage localStorage.removeItem('name'); localStorage.removeItem('email'); localStorage.removeItem('phone'); } } ``` 这样,当用户重新访问该页面时,表单数据将从本地存储中自动填充。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值