# HTTP笔试部分 点击关注本[公众号](https://ihavenolimitations.xyz/book/dsh225/javascript_vue_css/edit#_118)获取文档最新更新,并可以领取配套于本指南的《**前端面试手册**》以及**最标准的简历模板**. [TOC] > 此部分是我早前在网上搜集的,已无法找出出处 ## 缓存题 假设我们有一个HTML页面,如下: ~~~ <!-- page.html --> <!DOCTYPE html> http://www.w3.org/1999/xhtml"> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> <title>page页</title> </head> <body> <img src="images/head.png" /> <a href="page.html">重新访问page页</a> </body> </html> ~~~ 加载此页面后,会获取图片,图片请求返回的响应头为 ~~~ HTTP/1.1 200 OK Cache-Control: no-cache Content-Type: image/png Last-Modified: Tue, 08 Nov 2016 06:59:00 GMT Accept-Ranges: bytes Date: Thu, 10 Nov 2016 02:48:50 GMT Content-Length: 3534 ~~~ ### 问题一:当点击“重新访问 page 页”链接重新加载该页面后, head.png 如何二次加载? 响应头的`no-cache`表达的是可以缓存,但是每次都需要去服务器确认缓存资源的新鲜度,而不是不缓存,这是个坑。 ~~~ Cache-Control: no-cache ~~~ 如果不跳这个坑的话,这个问题就简单了:图片会发出请求头带上`If-Modified-Since: Tue, 08 Nov 2016 06:59:00 GMT`,服务器确认新鲜度,如果客户端资源是新鲜资源则返回304,否则返回200并带上新的图片资源。 ### 问题二:如果将上述信息中的 Cache-Control 设置为 private,那么结果又会如何呢? 当`Cache-Control: private`之后,说明一个问题,响应头没有给到任何缓存策略,这个时候客户端会怎么处理? 现在浏览器会有一个处理方法,当响应头没有任何缓存策略的时候有一套自己的处理机制,即`Expires = 当前时间(Date - Last-Modified) * 10%`,简单理解就是响应头的Date时间与Last-Modified的时间差的十分之一作为缓存的过期时间。 按照这个处理流程,如果马上重新加载,则会直接读取本地缓存内容 ,无需向服务器请求。 * * * ## ajax和axios、fetch的区别 https://www.jianshu.com/p/8bc48f8fde75 ## 公众号 想要实时关注笔者最新的文章和最新的文档更新请关注公众号**程序员面试官**,后续的文章会优先在公众号更新. **简历模板**:关注公众号回复「模板」获取 《**前端面试手册**》:配套于本指南的突击手册,关注公众号回复「fed」获取 ![2019-08-12-03-18-41](https://xiaomuzhu-image.oss-cn-beijing.aliyuncs.com/d846f65d5025c4b6c4619662a0669503.png)