美文网首页IT修真院-前端
在浏览器地址栏输入URL,按下回车后究竟发生了什么?

在浏览器地址栏输入URL,按下回车后究竟发生了什么?

作者: 未成年面包_d036 | 来源:发表于2017-09-29 10:48 被阅读0次

    大家好,我是IT修真院北京分院25期的学员,一枚正直纯洁善良的web前端程序员

    今天给大家分享一下,修真院官网js任务11,深度思考中的知识点——移动端有哪些常见的布局方式?

    1.背景介绍

    当你在浏览器地址栏输入一个URL后回车,将会发生的事情?这是一道经典的面试题,同时也是一道复杂的题目,涉及到很多东西,不同的软件开发者对于此道问题有不同的答案,对于其中的某一点也能无限深究,今天我们就来侧重于web前端来看一下究竟发生了什么。

    2.知识剖析

    关于URL

    URL(Universal Resource Locator):统一资源定位符。俗称网页地址或者网址。URL用来表示某个资源的地址。

    URL主要由以下几个部分组成: a.传输协议 b.服务器c.域名 d.端口e.虚拟目录 f.文件名 g.锚 h.参数

    连起来就是:http://www.aspxfans.com:8080/news/index.asp?boardID=5&ID=24618&page=1#name

    上面的链接有几个要注意的地方:“;” 和“/”的使用,80端口默认不显示,“?” 到“#”之间跟着参数,多个参数使用“&”连接,“#”后面跟着锚。

    基本流程

    查询ip地址

    建立tcp连接,接入服务器

    浏览器发起http请求

    服务器后台操作并做出响应

    浏览器渲染页面

    3.常见问题

    具体步骤?

    4.解决方案

    查询ip地址

    浏览器解析出url中的域名

    查询浏览器的DNS缓存

    浏览器中没有DNS缓存,则查找本地客户端hosts文件有无对应的ip地址

    hosts中无,则查找本地DNS服务器(运营商提供的DNS服务器)有无对应的DNS缓存

    若本地DNS没有DNS缓存,则向根服务器查询,进行递归查找

    递归查找从顶级域名开始(如.com),一步步缩小范围,最终客户端取得ip地址

    tcp连接与http连接

    http协议建立在tcp协议之上,http请求前,需先进行tcp连接,形成客户端到服务器的稳定的通道。俗称TCP的三次握手

    tcp连接完成后,http请求开始,请求有多种方式,常见的有get,post等

    http请求包含请求头,也可能包含请求体两部分,请求头中包含我们希望对请求文件的操作的信息,请求体中包含传递给后台的参数。

    服务器收到http请求后,后台开始工作,如负载平衡,跨域等,这里就是后端的工作了。

    文件处理完毕,生成响应数据包,响应也包含两部分,响应头和响应体,响应体就是我们所请求的文件

    经过网络传输,文件被下载到本地客户端,客户端开始加载

    html渲染

    客户端浏览器加载了html文件后,由上到下解析html为DOM树(DOM Tree)

    遇到css文件,css中的url发起http请求。

    这是第二次http请求,由于http1.1协议增加了Connection: keep-alive声明,故tcp连接不会关闭,可以复用。

    http连接是无状态连接,客户端与服务器端需要重新发起请求--响应

    在请求css的过程中,解析器继续解析html,然后到了script标签。

    由于script可能会改变DOM结构,故解析器停止生成DOM树,解析器被js阻塞,等待js文件发起http请求,然后加载。这是第三次http请求。js执行完成后解析器继续解析。

    由于css文件可能会影响js文件的执行结果,因此需等css文件加载完成后再执行。

    浏览器收到css文件后,开始解析css文件为CSSOM树(CSS Rule Tree)。

    CSSOM树生成后,DOM Tree与CSS Rule Tree结合生成渲染树(Render Tree),

    Render Tree会被css文件阻塞,渲染树生成后,先布局,绘制渲染树中节点的属性(位置,宽度,大小等),然后渲染,页面就会呈现信息。

    继续边解析边渲染,遇到了另一个js文件,js文件执行后改变了DOM树,渲染树从被改变的dom开始再次渲染

    继续向下渲染,碰到一个img标签,浏览器发起http请求,不会等待img加载完成,继续向下渲染,之后再重新渲染此部分。

    DOM树遇到html结束标签,停止解析,进而渲染结束

    5.编码实战

    6.扩展思考

    有哪些网站优化的方法

    减少DNS查询:将服务器域名的ip信息加入本地host文件

    减少http请求数量,比如使用雪碧图,对于html文件和css文件,js文件分别进行合并操作。

    减少下载时间:压缩图片,使用压缩应用压缩文档中的空格,删除文件多余的语句和注释,使用js精简库和精简框架,使用本地浏览器缓存。

    提前渲染开始时间:将css链接放在html头部

    减轻解析器的阻塞:将js链接放在body尾部

    7.参考文献

    参考一:当我们输入URI,按下回车发生了什么?

    参考二:当你在浏览器地址栏输入一个URL后回车,将会发生的事情?

    8.更多讨论

    PPT

    视频:密码: qczv

    技能树.IT修真院

    “我们相信人人都可以成为一个工程师,现在开始,找个师兄,带你入门,掌控自己学习的节奏,学习的路上不再迷茫”。

    这里是技能树.IT修真院,成千上万的师兄在这里找到了自己的学习路线,学习透明化,成长可见化,师兄1对1免费指导。快来与我一起学习吧 !

    猛戳这里

    相关文章

      网友评论

        本文标题:在浏览器地址栏输入URL,按下回车后究竟发生了什么?

        本文链接:https://www.haomeiwen.com/subject/kavvextx.html