首页
题库
公司真题
专项练习
面试题库
在线编程
面试
面试经验
AI 模拟面试
简历
求职
学习
基础学习课
实战项目课
求职辅导课
专栏&文章
竞赛
搜索
我要招人
发布职位
发布职位、邀约牛人
更多企业解决方案
AI面试、笔试、校招、雇品
HR免费试用AI面试
最新面试提效必备
登录
/
注册
just_to_do
广州大学华软软件学院 前端工程师
关注
已关注
取消关注
实用
@阿珊和她的猫:
前端面试必备 | 浏览器缓存篇(P1-10)
文章目录 什么是浏览器缓存?它在前端开发中的作用是什么? 解释一下浏览器缓存中的强缓存和协商缓存的概念及其区别。 HTTP响应头中的Cache-Control和Expires分别用于设置什么类型的缓存策略? 什么是ETag?它在浏览器缓存中的作用是什么? 解释一下缓存验证的过程是如何进行的(即协商缓存的机制)? 如果要禁用浏览器缓存,你会采取什么措施? 如何在前端代码中设置缓存策略,以便利用浏览器缓存? 解释一下缓存清除(缓存刷新)的几种方法和情况。 什么是缓存穿透?如何在前端防止缓存穿透的问题? 解释一下前端开发中常见的缓存失效场景及其解决方案。 1. 什么是浏览器缓存?它在前端开发中的作用是什么? 浏览器缓存是指浏览器在访问网页时将一些数据(如HTML、CSS、JavaScript文件、图像等)存储在客户端本地的临时存储空间中。这样,在用户再次访问同一个页面时,浏览器可以直接从缓存中加载这些数据,而无需重新从服务器下载。 浏览器缓存在前端开发中起到了几个重要的作用: 提升性能和加快加载速度:通过使用缓存,浏览器避免了重复下载相同的资源文件,减少了服务器的负担和网络传输时间,从而加快了页面加载速度。 减少网络流量和节省带宽:如果网页的资源文件已经存在于浏览器缓存中,并且没有过期,那么浏览器可以直接从缓存中获取资源,而无需再次向服务器请求,从而减少了网络流量和带宽的消耗。 离线访问支持:浏览器缓存还可以使网页在离线状态下继续访问,如果用户已经访问过某个页面并缓存了相应的资源,当用户离线时,浏览器可以从缓存中加载并显示页面内容。 在前端开发中,开发者可以利用浏览器缓存来优化网页性能和用户体验。通过正确地设置缓存策略,开发者可以控制文件的缓存时间、缓存级别以及是否允许缓存等,从而实现更好的资源管理和更新策略。同时,开发者还可以使用版本控制或文件指纹等技术来确保更新的文件可以被浏览器正确地识别和获取,避免缓存旧的文件造成的问题。总之,合理利用浏览器缓存可以显著提升网页加载速度和性能,提升用户体验。 2. 解释一下浏览器缓存中的强缓存和协商缓存的概念及其区别。 在浏览器缓存中,可以通过两种方式来控制缓存的行为:强缓存和协商缓存。 强缓存(Cache-Control 和 Expires):强缓存是通过在服务器响应头中设置相关的缓存策略信息,使浏览器在接收到响应后直接从缓存中获取资源,而无需与服务器进行通信。 Cache-Control:该响应头字段指定了资源的缓存策略。常见的值包括: max-age=<seconds>:指定资源在缓存中的有效时间,单位为秒。例如,max-age=3600表示资源在缓存中有效一小时。 no-cache:表示每次请求都要与服务器进行验证,不能直接使用缓存。 no-store:表示不缓存任何请求或响应的内容。 Expires:该响应头字段指定了资源的过期时间,是一个具体的日期时间。当浏览器接收到带有 Expires 响应头的资源时,会将资源缓存在本地,并在过期时间之前直接使用缓存。 强缓存优先级高于协商缓存,当强缓存生效时,直接使用缓存,不会发送请求到服务器。 协商缓存(Last-Modified 和 ETag):协商缓存是在浏览器发送请求时与服务器进行通信,通过比较资源的标识符来确定是否使用缓存。 Last-Modified 和 If-Modified-Since:服务器在响应头中返回资源的最后修改时间(Last-Modified),浏览器在后续请求中通过 If-Modified-Since 头字段将上次请求返回的最后修改时间发送给服务器。如果资源在此时间后没有发生变化,服务器会返回 304 Not Modified 状态码,告诉浏览器可以使用缓存。 ETag 和 If-None-Match:服务器在响应头中返回资源的唯一标识符(ETag),浏览器在后续请求中通过 If-None-Match 头字段将上次请求返回的 ETag 发送给服务器。如果资源的 ETag 与服务器上的匹配,服务器会返回 304 Not Modified 状态码。 协商缓存是根据服务器与浏览器之间的通信来确定是否使用缓存。如果协商缓存生效,服务器会返回很小的响应结果,节省了带宽的使用。 区别: 强缓存是通过在服务器响应头中设置缓存策略信息,浏览器在接收到响应后直接从缓存中获取资源。而协商缓存是在请求时与服务器通信,由服务器返回状态码来决定是否使用缓存。 强缓存的优先级比协商缓存高,如果强缓存生效,浏览器不会发送请求到服务器。而协商缓存需要发送请求到服务器进行验证。 强缓存使用 Cache-Control 和 Expires 头字段进行控制,而协商缓存使用 Last-Modified 和 ETag 头字段进行验证。 强缓存适用于静态资源,而协商缓存适用于需要频繁变动的资源。 通常情况下,开发者可以结合使用强缓存和协商缓存策略,以最大程度地提高缓存的效果和性能。 3. HTTP响应头中的Cache-Control和Expires分别用于设置什么类型的缓存策略? Cache-Control 和 Expires 是用于设置强缓存的缓存策略。 Cache-Control:Cache-Control 是一个用于指定缓存行为的响应头字段。它可以通过设置不同的指令来控制缓存的行为。 max-age=:指定资源在缓存中的最大有效时间,单位为秒。例如,Cache-Control: max-age=3600 表示资源在缓存中有效一小时。 no-cache:表示每次请求都要与服务器进行验证,不能直接使用缓存。 no-store:表示不缓存任何请求或响应的内容。 public:表示响应可以被任何缓存(包括客户端和中间代理服务器)缓存。 private:表示响应只能被客户端缓存,中间代理服务器不应该缓存响应。 这些指令可以单独使用或者组合使用,以定义缓存的行为。通过 Cache-Control,开发者可以灵活地控制缓存的有效期、缓存级别和缓存的访问权限。 Expires:Expires 是一个响应头字段,用于指定资源的过期时间,是一个具体的日期时间。浏览器在接收到带有 Expires 响应头的资源时,会将资源缓存在本地,并在过期时间之前直接使用缓存。 例如,Expires: Wed, 21 Oct 2023 07:28:00 GMT 表示资源在 2023 年 10 月 21 日 07:28:00 GMT 之前有效。 Cache-Control 是 HTTP/1.1 的标准字段,而 Expires 是 HTTP/1.0 的字段。Cache-Control 提供了更多的缓存控制选项,更为灵活,并且在功能上覆盖了 Expires 的功能。因此,在支持 HTTP/1.1 的情况下,建议优先使用 Cache-Control 来设置缓存策略。 同时,需要注意的是,如果同时使用了 Cache-Control 和 Expires,Cache-Control 的优先级更高。因为 Cache-Control 是比 Expires 更新的规范,并且提供了更多的缓存控制选项。 4. 什么是ETag?它在浏览器缓存中的作用是什么? ETag(Entity Tag)是一个由服务器生成的用于标识资源的唯一标识符。 ETag 在浏览器缓存中的作用是协商缓存的一部分。当浏览器发送请求时,会将上一次请求返回的 ETag 值通过 If-None-Match 请求头字段发送给服务器。服务器使用这个值与当前资源的 ETag 进行比较,以判断资源是否发生了变化。 如果服务器发现资源的 ETag 值与浏览器发送的匹配,并且资源没有发生变化,服务器会返回状态码 304 Not Modified,表示资源未修改。浏览器收到这个响应后,可以直接从缓存中获取资源,而无需重新下载。 ETag 能够精确地确定资源是否发生了变化,相对于 Last-Modified(最后修改时间)来说更加准确。如果资源的内容发生了任何改变,服务器会为该资源生成新的 ETag 值,而 Last-Modified 只能以秒级别的精度表示时间,可能无法捕捉到非常小的修改。 在大多数情况下,浏览器会使用 Cache-Control 和 ETag(或 Last-Modified)一起使用,以提供更精确和可靠的缓存控制。当 Cache-Control 的缓存过期策略失效时,浏览器会使用 ETag 和服务器进行协商,以便确定是否可以使用缓存的副本。如果服务器返回 304 Not Modified,浏览器就可以直接使用缓存,并避免重新下载资源。这样可以减少网络带宽的使用,并提高页面加载速度和性能。 5. 解释一下缓存验证的过程是
点赞 5
评论 4
全部评论
推荐
最新
楼层
暂无评论,快来抢首评~
相关推荐
昨天 19:56
清华大学 机械设计/制造
第一学历重要还是硕士学历重要?
大家好,今天给大家分享第一学历重要还是硕士学历重要。下面汇总了不同观点,大家可以参考。观点1:你没有哪个,哪个就重要。结论,凡是你没有的都是重要的,你一旦拥有了就不重要了。观点2:体制内就学历重要,进厂第一学历更重要。观点3:目前大厂情况是,985本>双非本985硕>双非研究生。观点4:211本硕打不了9硕双非本。除非是垃圾二本之类的。卡第一学历大部分好点的公司干脆直接卡985本,比亚迪这种算特例了。整体待遇211本硕比不了单9硕。观点5:在中等985里的硕士,很多都是211或者普通一本的本科,一般一个学校研究生最好的生源就是本校的本科生。观点6:9硕双非本排211本后面。观点7:第一学历还是...
点赞
评论
收藏
分享
02-02 10:47
禾赛科技_嵌入式软件工程师(准入职员工)
禾赛科技内推,禾赛科技内推码
禾赛科技 嵌入式开发(操作系统)面经⚜技术是真的过硬啊,秋招嵌入式被拷打的最狠之一。原定45分钟,拷打一个半小时,涉及知识面特别广,实际问的比这还要多,记忆有限。不过也无后续,但也没挂,估计在L3缓存里面吧⭕一面(9.18)1. 自我介绍2. 项目介绍3. 有没有测量IMU精度4. 串口有几根线,中断配置?5. IIC有几根线?讲一讲怎么通信?详细说一下读取寄存器的流程6. 说一说任务有哪几种状态?就绪和阻塞的任务放在哪里?放在同一个链表上面吗?7. 任务怎么进入阻塞态?(主动挂起,被强占,争取不到资源等)8. 说一说死锁?9. 怎么解决死锁问题?(获取不到锁的时候,释放本身的资源)10. 有...
点赞
评论
收藏
分享
01-31 11:59
蚌埠坦克学院 后端工程师
看似0,实则100%
有人零实习也能进大厂,是因为他们手里有比实习更硬的底牌,高学历背景,985、211的毕业证本身就是一块金字招牌,或者丰富的科研经历,发表过高质量的论文,参与过前沿项目,这些都是能力的直接证明;亦或是那些高含金量的奖项,像ACM竞赛的金奖、Kaggle比赛的高排名,这些都能让招聘官一眼相中,当然,家庭背景硬也是一种隐性优势。总之,没有人能够无缘无故的进入大厂,当然家庭背景很硬也是一种能力
为什么有人零实习也能进大...
点赞
评论
收藏
分享
01-20 02:07
中国矿业大学 大数据开发工程师
年前能找到实习吗
好焦虑 方向确定的太晚了
点赞
评论
收藏
分享
01-31 13:33
腾讯_Android客户端开发
字节飞书 安卓二面
自我介绍自定义 View 和自定义 ViewGroup 的实现流程?安卓界面刷新的垂直同步信号是什么,有什么作用?如何从内存和卡顿两个角度优化 UI 性能?安卓中 ANR 的触发阈值是什么,底层是如何检测 ANR 的?除了约束布局,还有哪些布局优化手段?RecyclerView 相比 ListView 有哪些性能优势?屏幕适配中,尺度修饰符(如 sw600dp)的作用是什么?如何根据不同屏幕尺寸加载对应布局?volatile 关键字的作用是什么,能保证并发的哪些特性(可见性、有序性、原子性)?volatile 关键字底层是如何实现的,内存屏障的作用是什么?单例模式中如何使用 volatile ...
查看22道真题和解析
点赞
评论
收藏
分享
评论
点赞成功,聊一聊 >
1
收藏
分享
评论
提到的真题
返回内容
全站热榜
更多
1
...
双非大三生在家20小时写了个Agent开源项目
5280
2
...
害怕被嘲笑就不去做了吗?
3939
3
...
字节国际化广告后端一面
3161
4
...
小红书前端一面
3082
5
...
阿里社招一面
2637
6
...
字节的offer流程需要多久
2457
7
...
程序员找工作至少要刷多少题
1854
8
...
我被美团二面面试官嘲笑
1823
9
...
AI大模型从业者聊Agent:附上学习路径
1621
10
...
字节日常实习二面
1555
创作者周榜
更多
正在热议
更多
#
在大厂上班是一种什么样的体验
#
7103次浏览
104人参与
#
机械人避雷的岗位/公司
#
42048次浏览
280人参与
#
程序员找工作至少要刷多少题?
#
13131次浏览
202人参与
#
12306一秒售罄,你抢到回家的票了吗?
#
1210次浏览
39人参与
#
我现在比当时_,你想录用我吗
#
5881次浏览
89人参与
#
过年最难忘的一件事
#
23067次浏览
174人参与
#
你最满意的offer薪资是哪家公司?
#
69510次浏览
349人参与
#
为了减少AI幻觉,你注入过哪些设定?
#
2702次浏览
97人参与
#
牛客AI体验站
#
4858次浏览
149人参与
#
AI Coding的使用心得
#
3552次浏览
91人参与
#
找工作的破防时刻
#
253180次浏览
1962人参与
#
刚入职的你踩过哪些坑
#
5403次浏览
113人参与
#
论秋招对个人心气的改变
#
7407次浏览
130人参与
#
一张图晒一下你的AI员工
#
3654次浏览
82人参与
#
关于春招/暑期实习,你想知道哪些信息?
#
5448次浏览
98人参与
#
黄金这个事上,你学到了什么
#
1306次浏览
41人参与
#
机械人你知道哪些单休企业
#
85502次浏览
428人参与
#
程序员能干到多少岁?
#
6849次浏览
104人参与
#
晒晒你司的新年福利
#
5606次浏览
89人参与
#
关于提前批我想问
#
267527次浏览
2307人参与
牛客网
牛客网在线编程
牛客网题解
牛客企业服务