大致能分成两个部分:网络通信与页面渲染

一.网络通信

互联网各个网络设备间的通信均基于TCP/IP协议,此协议将整个过程进行分层,由上至下分别为: 应用层、传输层、网络层和数据链路层

1.输入URL

2.应用层用DNS解析域名(DNS协议)

解析url域名,检查本地是否有对应的IP地址,有则返回,没有则请求上级DNS服务器

备注:DNS domain name system,由解析器和域名服务器组成,主要用于解析域名为IP地址

3.应用层发送http请求(HTTP协议)

http请求由请求报头与请求体组成,请求体为请求的数据,请求头包含请求方式(get、post。。)协议(http、https。。)是否包含cookie等信息

4.传输层传输报文(TCP协议)

为了方便传输将IP协议大块的数据分割为以报文段为单位的小数据包,并为其标号,方便服务端还原。

为了保证传输的安全可靠,将经历TCP三次握手:
发送端发送带有SYN标志的数据包给接收端,在一定的时间内等待回复;

接受端接收到数据包并确认无误后发送带有SYN/ACK标志的数据包给发送端,代表已接收,确认无误;

发送端再发送带有ACK标志的数据包给接收端代表握手成功。

SYN: synchronize 同步

ACK:Acknowledgement 确认

5.网络层查询MAC地址(IP协议)

IP协议的作用是把分割好得报文发送给服务端,但在此之前得先知道对方的MAC地址。

IP地址与MAC一一对应,IP地址能随意换,但MAC不会变,提供ARP协议查询到MAC地址

MAC: media access control 媒体访问控制,可理解为物理地址,硬件地址,每个设备都有独一无二的MAC地址

6.数据链路层传输数据

提供数据链路层传输数据,至此客户端发送完毕。

7.服务端接收数据

客户端在数据链路层获取数据,层层上传至应用层,在传递过程中将数据包还原成完整的http请求

8.服务端响应请求

服务端找到资源并返回响应报文,响应报文中包括一个重要的信息——状态码。状态码由三位数字组成,其中比较常见的是200 OK表示请求成功。301表示永久重定向,即请求的资源已经永久转移到新的位置。在返回301状态码的同时,响应报文也会附带重定向的url,客户端接收到后将http请求的url做相应的改变再重新发送。404 not found 表示客户端请求的资源找不到。

9.请求成功后返回html文件,进入页面渲染阶段

二、页面渲染

1.解析HTML构建DOM树,即由节点构成的树

解析和构建同时进行,由上至下地进行解析,这里注意几点:

a.外部样式的加载不会阻塞dom树的构建,但会阻塞其渲染

b.外部样式的加载不会阻塞脚本的加载,但会阻塞其执行

c.如果外部脚本加上async(IR为defer),设为异步,则外部样式不会阻塞其执行

d.动态加载的外部样式不影响脚本的执行

e.script一般放在最后面,因为它的加载和执行会阻塞页面的渲染,也就是说它的加载执行是同步的

2.(style)构建渲染树,即将css样式应用到dom树上,构建CSSOM树

webkit称之为附着

3.(layout)布局

树节点的大小、位置信息等的运算,构建渲染树

4.(painting)绘制

将树绘制在屏幕上。

本文总结自:http://www.cnblogs.com/kongxy/p/4615226.html与http://www.cnblogs.com/dojo-lzz/p/3983335.html

从输入url到浏览器呈现网页发生了什么?的更多相关文章

  1. 从浏览器地址栏输入URL到浏览器呈现数据全过程解析

    一.输入设备(或粘贴)输入 URL,按下 Enter键 或其他按钮开始请求. 二.浏览器开始解析 URL 关于 URL 到相关知识点:什么是URI,URL以及URN,你真的理解了吗. 1.URL 是否 ...

  2. 从输入URL到浏览器显示页面发生了哪些事情---个人理解

    经典面试题:从输入URL到页面显示发生了哪些事情 以前一直都记不住,这次自己理解了一下 用自己的话总结了一次,不对的地方希望大佬给我指出来 1.主机通过DHCP协议获取客户端的IP地址.子网掩码和DN ...

  3. 从输入URL到浏览器显示页面发生了什么

    1.输入网址 当你开始输入网址比如www.cnblogs.com时游览器就可以在书签或者历史记录里面去搜索相关的网址推荐给你. 2.游览器查找域名的IP地址 ① 请求发起后,游览器首先会解析这个域名, ...

  4. 深入浅出经典面试题:从浏览器中输入URL到页面加载发生了什么 - Part 3

    备注: 因为文章太长,所以将它分为三部分,本文是第三部分. 第一部分:深入浅出经典面试题:从浏览器中输入URL到页面加载发生了什么 - Part 1 第二部分:深入浅出经典面试题:从浏览器中输入URL ...

  5. 在浏览器中输入URL按下回车键后发生了什么

    在浏览器中输入URL按下回车键后发生了什么 [1]解析URL[2]DNS查询,解析域名,将域名解析为IP地址[3]ARP广播,根据IP地址来解析MAC地址[4]分别从应用层到传输层.网络层和数据链路层 ...

  6. 从输入 URL 到浏览器接收的过程中发生了什么事情

    从输入 URL 到浏览器接收的过程中发生了什么事情? 原文:http://www.codeceo.com/article/url-cpu-broswer.html 从触屏到 CPU  首先是「输入 U ...

  7. 从输入 URL 到浏览器接收的过程中发生了什么事情?

    从输入 URL 到浏览器接收的过程中发生了什么事情? What really happens when you navigate to a URL 上面两篇文章都解读的很好,值得阅读. 接下来在总结一 ...

  8. 【ASP.NET Core】EF Core - “影子属性” 深入浅出经典面试题:从浏览器中输入URL到页面加载发生了什么 - Part 1

    [ASP.NET Core]EF Core - “影子属性”   有朋友说老周近来博客更新较慢,确实有些慢,因为有些 bug 要研究,另外就是老周把部分内容转到直播上面,所以写博客的内容减少了一点. ...

  9. 【原】老生常谈-从输入url到页面展示到底发生了什么

    刚开始写这篇文章还是挺纠结的,因为网上搜索“从输入url到页面展示到底发生了什么”,你可以搜到一大堆的资料.而且面试这道题基本是必考题,二月份面试的时候,虽然知道这个过程发生了什么,不过当面试官一步步 ...

随机推荐

  1. IIS7应用程序池集成和经典的区别 对IIS7经典模式和集成模式的理解 程序池经典和集成的区别

    IIS7应用程序池集成和经典的区别   IIS7应用程序池集成和经典的区别 IIS7应用程序池有集成和经典两种模式,根据微软官方的介绍, 集成模式,如果托管应用程序在采用集成模式的应用程序池中运行,服 ...

  2. mysql 主从切换

    4)提升slave为master Stop slave: Reset master; Reset slave all; 在5.6.3版本之后 Reset slave; 在5.6.3版本之前 查看sla ...

  3. Linux 查看tomcat占用的端口号

    第一步:先查看tomcat占用的进程号 ps -ef|grep tomcat 第二步:根据进程号,查看进程所占用的端口 netstat -apn 由此得知,tomcat的进程号是21845,并得到端口 ...

  4. 2017湘潭赛 A题 Determinant (高斯消元取模)

    链接 http://202.197.224.59/OnlineJudge2/index.php/Problem/read/id/1260 今年湘潭的A题 题意不难 大意是把n*(n+1)矩阵去掉某一列 ...

  5. HTML DOM节点的增删改查

    上篇博客中,我们已经初步接触了DOM基础,可是我们学习是为了可以更好地应用,今天我们就来看看DOM节点的增删改查. 无论在哪里,我们想要操作一个东西,总是应该先去获得它.那么我们怎么获得呢? HTML ...

  6. 正负小数点后两位浮点数--jquery

    背景:项目中需要做个对两位小数点的正负浮点数的处理, 要求:非数字或者.字符自动清除,并对.12自动修补.前的0 原理:在输入框中加入两个事件,keyup与blur,keyup处理字符串中非要求的字符 ...

  7. CentOS 7 mini 试用笔记

    CentOS 7 mini 试用笔记 安装过程中,网卡是默认关闭的,要手动打开. 安装好以后,查看IP地址:# ip addr----------------------1: lo: 本地回环2: e ...

  8. 如何通过Git命令行把代码提交到github上

    1.http://www.cnblogs.com/leesf456/p/5169765.html   参考博客 背景:最近入手了mac,看见mac上的大神都是在用git命令行推代码,我很羡慕有木有,好 ...

  9. 数字证书转换cer---pem

    下载openssl-1.0.1s 安装好openssl之后,进入openssl目录:   输入openssl命令,即进入命令模式:   先将要转换的cer证书也放到openssl目录下面,然后执行以下 ...

  10. Entity Framework(1)——Connections and Models

    原文:https://msdn.microsoft.com/en-us/data/jj592674 应该选择CodeFirst.ModelFirst还是databaseFirst网上已经很多资料了,这 ...