回味JS(十)浏览器相关

2019-07-07  本文已影响0人  ArmorVon

网页中有哪些嵌入 JavaScript 代码的方法?

为什么script 元素最好放在body的最后?

defer属性的运行流程是怎样的?

  1. 浏览器开始解析 HTML 网页。
  2. 解析过程中,发现带有defer属性的<script>元素。
  3. 浏览器继续往下解析 HTML 网页,不会阻塞浏览器,同时并行下载<script>元素加载的外部脚本。
  4. 浏览器完成解析 HTML 网页,此时再回过头执行已经下载完成的脚本。

async属性的运行流程?

  1. 浏览器开始解析 HTML 网页。
  2. 解析过程中,发现带有async属性的script标签。
  3. 浏览器继续往下解析 HTML 网页,同时并行下载<script>标签中的外部脚本。
  4. 脚本下载完成,浏览器暂停解析 HTML 网页,开始执行下载的脚本。
  5. 脚本执行完毕,浏览器恢复解析 HTML 网页。

defer属性和async属性到底应该使用哪一个?

一般来说,如果脚本之间没有依赖关系,就使用async属性,如果脚本之间有依赖关系,就使用defer属性。如果同时使用async和defer属性,后者不起作用,浏览器行为由async属性决定

浏览器的核心是哪两部分?

常见的浏览器对应的渲染引擎是?

渲染引擎处理网页的过程?

  1. 解析代码:HTML 代码解析为 DOM,CSS 代码解析为 CSSOM(CSS Object Model)。
  2. 对象合成:将 DOM 和 CSSOM 合成一棵渲染树(render tree)。
  3. 布局:计算出渲染树的布局(layout)。
  4. 绘制:将渲染树绘制到屏幕。

什么是重流和重绘?

关于DOM有哪些优化技巧?

cookie有什么作用?

常用于:

Cookie 包含哪些信息?

删除cookie的方法?

删除一个现存 Cookie 的唯一方法,是设置它的expires属性为一个过去的日期。

document.cookie = 'fontSize=;expires=Thu, 01-Jan-1970 00:00:01 GMT';

什么是同源策略?

同源政策的目的?

为了保证用户信息的安全,防止恶意的网站窃取数据

解决跨域的几个方法?

CORS 通信的过程?

  1. 简单请求(HEAD、GET、POST):
    • 浏览器直接发出 CORS 请求,在头信息之中,增加一个Origin字段表示本次请求来自哪个域(协议 + 域名 + 端口)。服务器根据这个值,决定是否同意这次请求。
    • 如果回应的头信息没有包含Access-Control-Allow-Origin字段,表示Origin指定的源,不在许可范围内。
  2. 非简单请求(如请求方法是PUT或DELETE,或者Content-Type字段的类型是application/json)
    • 在正式通信之前,需增加一次 HTTP 查询请求,称为“预检”请求(preflight)。浏览器先询问服务器,当前网页所在的域名是否在服务器的许可名单之中,以及可以使用哪些 HTTP 动词和头信息字段
    • “预检”请求用的请求方法是OPTIONS,表示这个请求是用来询问的。头信息里面,关键字段是Origin,表示请求来自哪个源
    • 同样的,如果确认允许跨源请求,服务器会返回带有Access-Control-Allow-Origin字段的,如果不允许跨源请求,可能不会返回任何 CORS 相关的头信息字段,也可能返回的Access-Control-Allow-Origin明确不包括请求的域,此时就不可以进行请求

sessionStorage和localStorage的作用和区别?

上一篇 下一篇

猜你喜欢

热点阅读