从浏览器地址栏输入url到显示页面的步骤

    1. 输入url,并点击搜索
    1. 从浏览器获取缓存(从浏览器http的header中读取,缓解服务器压力,提高页面加载效率)
    • 灰色的200代表是获取的浏览器缓存的数据,黑色的200是后端返回的数据
    • 协商缓存(优先级高)
      • 如果缓存有效(HTTP头部的expires【存过期时间,会存在浏览器和服务端时间有间隔的问题】和cache-control【存有效时间】(优先级高)),则直接将缓存中的数据显示在页面上
      • 如果缓存过期,从header中找到对应的参数,携带到请求中发送给服务器,服务器根据对应的参数,判断对应的资源是否更新,如果更新了就返回200状态码和对应的数据;未更新就返回304状态码(更新缓存过期时间并使用对应的缓存)
    • 强制缓存
      • 如果存在强制缓存,将其渲染在页面上
    • 如果缓存在硬盘内存(localStorage),浏览器关闭后,再次打开仍然存在,如果在内存缓存(sessionStorage),浏览器关闭后,数据被销毁
    • 如果没有缓存或者缓存过期,则进行下一步
    1. 解析URL获取协议,域名和端口号
    1. 组装http请求报文
    1. 通过DNS域名解析获取IP
    1. 建立TCP连接
    1. 发送http请求
    1. 通过TCP连接接受后端发送来的数据
    1. 解析响应报文
    1. 生成虚拟DOM
    • 可以加快页面更改速度,只需要用diff算法对比新旧虚拟DOM的变化,更改发生变化的页面元素
    • 缺点:占内存,页面越复杂越占内存
    1. 初始化响应数据
    1. 根据HTTP生成DOM树,CSS生成CSSOM树
    1. 渲染可见元素(不可见:<script>标签、<meta>【用于指定网页的描述,关键词】标签,设置为display:none或其他不可见的元素)
    1. 根据CSS规则渲染相应元素
    1. 解析js
    1. 显示页面
    • 生命周期钩子触发
    • 浏览器渲染
相关推荐
CappuccinoRose34 分钟前
CSS 语法学习文档(十七)
前端·css·学习·布局·houdini·瀑布流布局·csspaintingapi
keyborad pianist1 小时前
Web开发 Day1
开发语言·前端·css·vue.js·前端框架
Never_Satisfied1 小时前
在HTML & CSS中,可能导致父元素无法根据子元素的尺寸自动调整大小的情况
前端·css·html
We་ct1 小时前
LeetCode 101. 对称二叉树:两种解法(递归+迭代)详解
前端·算法·leetcode·链表·typescript
码云数智-大飞1 小时前
微前端架构落地实战:qiankun vs Module Federation 2026 深度对比与选型指南
前端·架构
IT枫斗者1 小时前
MyBatis批量插入性能优化:从5分钟到3秒的工程化实践
前端·vue.js·mysql·mongodb·性能优化·mybatis
前端 贾公子2 小时前
深入理解 Vue3 的 v-model 及自定义指令的实现原理(中)
前端·html
Never_Satisfied2 小时前
在HTML & CSS中,img标签固定宽度时,img和图片保持比例缩放
前端·css·html
Cache技术分享2 小时前
327. Java Stream API - 实现 joining() 收集器:从简单到进阶
前端·后端
人工智能先锋2 小时前
从零部署你的24小时AI管家:OpenClaw完整实战指南(附踩坑记录)
前端·github