zoukankan      html  css  js  c++  java
  • 严格模式与混杂模式

    DOCTYPE是定义浏览器使用什么样的文本类型定义(DTD)载入页面。即告诉浏览器使用什么样的html或Xhtml规范解析html。一般放在(X)html文档开头用来告诉其他人文档类型风格。

    混杂模式

              含义:页面以比较宽松的向后兼容的方式显示,它通常模拟老式浏览器,比如(IE4)的行为,防止老站点无法工作。

              触发方式: 加入xml头部声明可以触发IE浏览器的Quirks mode,触发之后,浏览器解析方式就和IE5.5一样,拥有IE5.5一样的bug和其他问题,行为(Javascript)也是如此。   

              E6的触发 在XHTML的DOCTYPE前加入XML声明 IE7的触发 在XML声明和XHTML的DOCTYPE之间加入HTML注释 IE6和IE7都可以触发的 在HTML4.01的DOCTYPE文档头部加入HTML注释

    严格模式

             含义: 浏览器根据web标准去解析页面,是一种严格要求的DTD,不允许使用表面层的语法,

             触发方式 声明正确的DTD,便是严格模式。 在顶部添加“use strict”。也可以指定函数在严格模式下执行。

    如何区分浏览器解析时到底使用严格模式还是混杂模式,与网页中的 DTD 直接相关。

    1、如果文档包含严格的 DOCTYPE ,那么它一般以严格模式呈现。(严格 DTD ——严格模式) 
    2、包含过渡 DTD 和 URI 的 DOCTYPE ,也以严格模式呈现,但有过渡 DTD 而没有 URI (统一资源标识符,就是声明最后的地址)会导致页面以混杂模式呈现。(有 URI 的过渡 DTD ——严格模式;没有 URI 的过渡 DTD ——混杂模式) 
    3、DOCTYPE 不存在或形式不正确会导致文档以混杂模式呈现。(DTD不存在或者格式不正确——混杂模式)
    4、HTML5 没有 DTD ,因此也就没有严格模式与混杂模式的区别,HTML5 有相对宽松的语法,实现时,已经尽可能大的实现了向后兼容。( HTML5 没有严格和混杂之分)

    严格模式与混杂模式的语句解析不同点有哪些?

    1)盒模型的高宽包含内边距padding和边框border

      在W3C标准中,如果设置一个元素的宽度和高度,指的是元素内容的宽度和高度,而在IE5.5及以下的浏览器及其他版本的Quirks模式下,IE的宽度和高度还包含了padding和border。

    2)可以设置行内元素的高宽

        在Standards模式下,给span等行内元素设置wdith和height都不会生效,而在quirks模式下,则会生效。

    3)可设置百分比的高度

        在standards模式下,一个元素的高度是由其包含的内容来决定的,如果父元素没有设置高度,子元素设置一个百分比的高度是无效的。

    4)用margin:0 auto设置水平居中在IE下会失效

        使用margin:0 auto在standards模式下可以使元素水平居中,但在quirks模式下却会失效,quirk模式下的解决办法,用text-align属性:

       body{text-align:center};#content{text-align:left}

    5)quirk模式下设置图片的padding会失效

    6)quirk模式下Table中的字体属性不能继承上层的设置

    7)quirk模式下white-space:pre会失效

  • 相关阅读:
    160422、Highcharts后台获取数据
    160421、MyBatis批量插入数据
    微信小程序wx:for循环
    【小程序】获取到的e.target与e.currentTarget区别
    微信小程序如何像vue一样在动态绑定类名
    发布 Vant
    ZanUI-WeApp -- 一个颜值高、好用、易扩展的微信小程序 UI 库
    微信小程序 使用wxParse解析html
    精通移动端布局
    axios interceptors 拦截 , 页面跳转, token 验证 Vue+axios实现登陆拦截,axios封装(报错,鉴权,跳转,拦截,提示)
  • 原文地址:https://www.cnblogs.com/microcosm/p/6501622.html
Copyright © 2011-2022 走看看