博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
【前端面试的坑】浏览器的渲染模式
阅读量:4093 次
发布时间:2019-05-25

本文共 1092 字,大约阅读时间需要 3 分钟。

简述

在很久以前的网络上,页面通常有两种版本:为网景(Netscape)的 Navigator 准备的版本,以及为微软(Microsoft)的 Internet Explorer 准备的版本。当 W3C 创立网络标准后,为了不破坏当时既有的网站,浏览器不能直接弃用这些标准。因此,浏览器采用了两种模式,用以把能符合新规范的网站和老旧网站区分开。

浏览器渲染引擎族谱
目前浏览器的排版引擎有三种模式:怪异模式(Quirks mode)、接近标准模式(Almost standards mode)、以及标准模式(Standards mode)。

  • 标准模式:浏览器引入w3c的标准,按照w3c的标准进行界面渲染。
  • 怪异模式:浏览器采用自身标准(各个浏览器不同)进行界面渲染。
  • 接近标准模式:只有少数的怪异行为被实现。

怪癖模式和标准模式的区别

  1. 声明方面

    当页面没有!doctype声明或者!doctype声明中没有HTML4以上(包含HTML4)的DTD声明,则页面以quirks mode渲染,其他情况则以sdandars mode渲染。

  2. 盒模型方面

    怪异模式:

    在这里插入图片描述

    css怪异模式下

    盒子模型的 width = content + padding + border

    只要content+padding+border的宽度之和小于width,那么无论怎么变动padding和border,盒子的宽度都是不发生变化的,只是会缩小content的宽度,也就是说在怪异模式下,content的宽度是可变的,当content+padding+border的宽度大于width的宽度后,盒子会变大,变大后的差值就是content+padding+border-width。

    获取页面宽高值的 JS 代码

    cWidth=document.body.scrollWidth;cHeight=document.body.scrollHeight;

    标准模式

    在这里插入图片描述
    在标准模式下

    盒子模型的 width = content

    盒子模型的总宽度等于width+padding+border+margin,这四项有一项发生变化,盒子的宽度随之会发生变化。

    获取页面宽高值的 JS 代码

    cWidth=document.documentElement.scrollWidth;cHeight=document.documentElement.scrollHeight;

js 检测渲染模式的方法

alert(document.compatMode );

输出有两个可能值:

BackCompat --怪癖模式
CSS1Compat --标准模式

转载地址:http://bxvii.baihongyu.com/

你可能感兴趣的文章
建立广义表的算法
查看>>
6.2 HTTP1.1 通用首部字段
查看>>
6.3 请求首部字段
查看>>
新年感想
查看>>
6.4响应首部字段
查看>>
6.5 实体首部字段
查看>>
6.6 为Cookie服务的首部字段
查看>>
6.7 其它首部字段
查看>>
flask web中app.config.from_data方法原理介绍
查看>>
使用itsdangerous生成确认令牌
查看>>
python flaskweb开发 data = s.loads(token)原理分析
查看>>
python flasky web 邮件发不出去的几点原因(结尾有ubutun连不上网的解决办法)
查看>>
1.1 使用虚拟环境
查看>>
2.1 创建最简单的web程序
查看>>
2.2程序和请求上下文
查看>>
2.3 请求调度和请求钩子
查看>>
2.4 响应
查看>>
2.5 Flask扩展
查看>>
3.1 为什么要使用和如何使用模板
查看>>
3.2 模板中的变量
查看>>