博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
“浏览器模式”和“文档模式”之间的区别
阅读量:6189 次
发布时间:2019-06-21

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

只有IE浏览器中才会有“浏览器模式”和“文档模式”,兼容性视图涉及两个重要的功能便是“浏览器模式【browser mode】”和“文档模式【document mode】”,在IE8/IE9中按F12键,打开“开发人员工具”,在菜单栏中可以看到“浏览器模式”和“文档模式”的切换菜单,其中可以选择切换到IE7/8等不同的网页模式。这个设置之后在js中可以通过navigator.userAgent获得浏览器的版本,这个一般情况是与浏览器模式对应的,也可以通过Document.documentMode获得浏览器的文档模式,这个一般是与文档模式相对应的。如果浏览器模式与文档模式不一致的时候,我们一般认为还是以文档模式为准【渲染页面】。

       那“浏览器模式”和“文档模式”之间有什么区别呢?

       “浏览器模式”用于切换IE针对该网页的默认文档模式、对不同版本浏览器的条件备注解析、发送给网站服务器的用户代理(User-Agent)字符串的值。网站可以根据浏览器返回的不同用户代理字符串判断浏览器的版本和安装的功能,这样就可以向不同的浏览器返回不同的页面内容。用开发人员工具切换浏览器模式时,文档模式也会对应改变。
 
        默认情况下,IE8的浏览器模式为IE8。用户可以通过单击地址栏旁边的兼容性视图按钮来手动切换到不同的浏览器模式。在IE8中,IE8兼容性视图会以IE7文档模式来显示网页,同时会向服务器发送IE7的用户代理字符串。
 
        “文档模式”用于指定IE的页面排版引擎(Trident)以哪个版本的方式来解析并渲染网页代码。切换文档模式会导致网页被刷新,但不会更改用户代理字符串中的版本号,也不会从服务器重新下载网页。切换浏览器模式的同时,浏览器也会自动切换到相应的文档模式。<meta http-equiv="x-ua-compatible" content="IE=7" />这个就是指定文档模式为IE7,Trident会按照IE7模式去渲染页面元素。

        另外还有不同的,就是IE=7和IE=EmulateIE7,这两个有什么不同呢?IE=7是页面按照IE7去渲染,不考虑DocType,而IE=EmulateIE7是以兼容IE7的模式去渲染,考虑DocType。当然还有更例外的情况,就是真正的IE7与IE9下添加了<meta http-equiv="x-ua-compatible" content="IE=7" />也有不同的情况,前几天做浏览器兼容的时候就碰到过,那个只能到IE7浏览器下去调试了,并且要分析代码的逻辑。

原文链接:http://blog.csdn.net/jcx5083761/article/details/8668597

转载于:https://www.cnblogs.com/zhangym118/p/8308779.html

你可能感兴趣的文章
Apache Struts2高危漏洞(S2-057CVE-2018-11776)
查看>>
快速排序(算法导论中的版本)
查看>>
网页设计制作CSS实现隔行换色两种方法
查看>>
分布式爬虫(一)------------------分布式爬虫概述
查看>>
小作坊的大道理——读《走出软件作坊》有感
查看>>
php 接口类,抽象类 的实际作用
查看>>
webstorm 配合IIS使用
查看>>
hash,面向对象
查看>>
P3649 [APIO2014]回文串
查看>>
C++对二进制文件的操作实例
查看>>
Java开发必会的Linux命令 转载(http://www.importnew.com/17354.html)
查看>>
SpringBoot 的错误处理机制
查看>>
高并发架构系列:如何解决Redis雪崩、穿透、并发等5大难题
查看>>
Let’s Encrypt 免费ssl加密
查看>>
11.11 开课二个月零七天(ajax和bootstrp做弹窗)
查看>>
自定义控件之圆形的image
查看>>
《机电传动大作业》笔记一
查看>>
TypeScript 素描-变量声明
查看>>
查看字体列表,查看字体名称
查看>>
oracle 定时器调用存储过程
查看>>