1.浏览器内核指的是什么?

简化的浏览器=用户界面+渲染引擎+js解析引擎+数据存储+网络部件

而通常所说的浏览器内核指的是页面渲染引擎(rendering engine)。

2.渲染引擎 The rendering engine

渲染引擎的职责就是渲染,即在浏览器窗口中显示所请求的内容。

默认情况下,渲染引擎可以显示html、xml文档及图片,它也可以借助插件(一种浏览器扩展)显示其他类型数据,例如使用PDF阅读器插件,可以显示PDF格式。

各大厂商依据W3C标准有各自的代码实现,开发了很多种渲染引擎。

浏览器内核 代表浏览器

Trident(IE)

 IE4~IE9,Maxthon,The World(世界之窗),还有很多含兼容浏览模式的浏览器

Gecko(火狐)

Netscape,Mazilla Firefox(火狐)

Presto(已过时)

Opera7.0+,NDSBrowser,Wii Internet Channle

Webkit/Chromium

 Apple Safari 、Android 默认浏览器、Chrome(谷歌浏览器)

360、QQ、遨游、搜狗浏览器、Opera现在也转投webkit了

Blink

由谷歌开发基于webkit, 安卓4.4+以上内置浏览器、微信/QQ/内置浏览器
浏览器内核  内核特性

Gecko(火狐)

 Gecko的特点是代码完全公开,跨平台

Webkit/Chromium

 目前使用最广的内核。Chromium是谷歌基于Webkit进一步改进的内核。Chromium支持了多线程的HTML解析。

Blink

Blink是webkit的升级版本,安卓4.4+以上内置浏览器、微信/QQ/内置浏览器就是这个

目前的主流趋势是基于开源引擎的渲染引擎越来越繁荣,并呈现出百家齐放的状态,而移动端由于性能要求更苛刻,诞生出更多优秀的引擎。

未来优秀的引擎应该具备:开源、跨平台、高度符合W3C标准的特征。

3.浏览器CSS hack及js hack 举例

某些浏览器对某些CSS的语法不同、效果不一样、甚至不支持一些新特性,为了浏览器兼容(在不同浏览器下显示效果一致),需要Browserhacks技术。

  1. /* CSS hack*/

使用hacker我可以把浏览器分为3类:IE6 ;IE7和遨游;其他(IE8 chrome ff safari opera等)

◆IE6认识的hacker 是下划线_ 和星号 *

◆IE7 遨游认识的hacker是星号 *

比如有这样一个3段相连CSS设置:

  1. height:300px;*height:200px;_height:100px;

IE6下:height=300px->200px->100px; (css一路覆盖至最后)

IE7下:height=300px->200px;(最后一个IE7不认识)

其他浏览器:height:300px;(后面两个浏览器不认识)

更多css hack见这篇文章

  2./* JS hack*/

通过js来判断当前浏览器。

  1.利用userAgent属性值

  1. /* Firefox */
    var isFF = !!navigator.userAgent.match(/firefox/i);

    但大多浏览器都提供userAgent自定义修改,所以并不可信

  2. 利用浏览器特有对象
/*IE<7*/
var isIE = document.all && !document.querySelector;
/*IE8~10*/
var isIE = document.all && document.querySelector; /*IEversion*/
var ieVersion = /*@cc_on (function() {switch(@_jscript_version) {case 1.0: return 3; case 3.0: return 4; case 5.0: return 5; case 5.1: return 5; case 5.5: return 5.5; case 5.6: return 6; case 5.7: return 7; case 5.8: return 8; case 9: return 9; case 10: return 10;}})() || @*/ 0; /*firefox*/
var isFF = !!window.sidebar;
/* Chrome , Opera ≥ 14 , Android 4.0.4*/
var isChromium = !!window.chrome; /*Webkit*/
var isWebkit = 'WebkitAppearance' in document.documentElement.style; /*Opera ≤ 9.64*/
var isOpera = /^function \(/.test([].sort);
/*Opera */
var isOpera = !!window.opera; /*Safari*/
var isSafari = /constructor/i.test(window.HTMLElement);

更多js hack见http://browserhacks.com/

4.另外还有 Media Queries“媒体查询”(我的理解是屏幕适配)

常用的语法有:

1.为不同的屏幕类型写css,放在html头

<link href="css/reset.css" rel="stylesheet" type="text/css" media="screen" />

<link href="css/style.css" rel="stylesheet" type="text/css" media="all" />

<link rel="stylesheet" media="handheld and (max-width:480px), screen and (min-width:960px)" href="small.css" />

2.样式文件中使用:
   @media screenand and(max-width: 600px){
     选择器{
    属性:属性值;
     }
   }

参考文章

http://www.iplaysoft.com/browsers-engine.html

http://www.cnblogs.com/zfc2201/archive/2012/07/14/2591108.html

http://www.cnblogs.com/asqq/archive/2012/04/13/2445912.html

各大浏览器内核特性及对应的Browserhacks举例的更多相关文章

  1. 各大浏览器内核介绍(Rendering Engine)

    在介绍各大浏览器的内核之前,我们先来了解一下什么是浏览器内核. 所谓浏览器内核就是指浏览器最重要或者说核心的部分"Rendering Engine",译为"渲染引擎&qu ...

  2. 各大浏览器内核(Rendering Engine)

    记得刚开始写网页的时候,听童鞋们说各大浏览器的内核,也是懵懵懂懂的,知一不知其二,今天特地查一下: 内核只是一个通俗的说法,其英文名称为“Layout engine”,翻译过来就是“排版引擎”,也被称 ...

  3. 关于浏览器内核与javascript引擎的一些小知识

    浏览器是我们每天几乎都必须使用的软件产品,可是对于自己每天都接触的浏览器,很多同学其实对其一无所知.今天异次元就跟大家说说关于浏览器内核的一些事儿吧,好让你了解多一点稍微内在的东西. 在下面的文章中主 ...

  4. WPF系列教程——(三)使用Win10 Edge浏览器内核 - 简书

    原文:WPF系列教程--(三)使用Win10 Edge浏览器内核 - 简书 在需要显示一些 H5网站的时候自带的WebBrowser总是显示不了,WebBrowser使用的是IE内核,许多H5新特性都 ...

  5. css3中-moz、-ms、-webkit,-o分别代表的意思,以及微信浏览器内核分析

    这种方式在业界上统称:识别码.前缀 //-ms代表[ie]内核识别码 //-moz代表火狐[firefox]内核识别码 //-webkit代表谷歌[chrome]/苹果[safari]内核识别码 // ...

  6. 浏览器内核与js引擎

    摘要: 面试一个大公司的时候问到了一个问题,让我谈谈主要的浏览器内核以及他们的特点,当时并没有详细的回答,回来之后自己在网上找了找资料,总结了下分享给大家. 简介: 在维基百科上是这样介绍浏览器内核的 ...

  7. 浏览器内核-Webkit

    关键字:浏览器内核,浏览器引擎,Browser,Webkit,Blink,Chromium. 本文简单介绍一下各种浏览器内核.着种介绍一下Webkit.顾名思义,浏览器内核就是浏览器的核心部分,也可以 ...

  8. 各大浏览器CSS Hack收集

    各大浏览器CSS Hack收集  >>>>>>>>>>>>>>>>>>>>> ...

  9. 浏览器内核Trident/Gecko/WebKit/Presto

    “浏览器内核”主要指渲染引擎(Rendering Engine),负责解析网页语法(如HTML.JavaScript)并渲染.展示网页.因此,所谓的浏览器内核通常也就是指浏览器所采用的渲染引擎, 渲染 ...

随机推荐

  1. matlab 假设检验

    转自:http://blog.csdn.net/colddie/article/details/7773278 函数名称 函数说明 调用格式 正态总体的参数检验 ztest 单样本均值的z检验 (总体 ...

  2. NCspider项目总结

    下午就要答辩了,想把项目经历再总结一下. 项目分三个阶段. 第一阶段,是信息搜集整理阶段 要想法设法从各个门户网站上抓取到新闻和对应的评论数据.首先要分析网站结构. 1. 从哪里找到网站每日发布的所有 ...

  3. [转]HQL中的子查询

    原文地址:http://blog.csdn.net/xb12369/article/details/8638683 子查询:   子查询是SQL语句中非常重要的功能特性,它可以在SQL语句中利用另外一 ...

  4. 冰冻三尺非一日之寒--还是web

    第十五章  javascript(js) DOM编程 javascript介绍 JavaScript是一门编程语言,浏览器内置了JavaScript语言的解释器,所以在浏览器上按照JavaScript ...

  5. PHP curl报错“Problem (2) in the Chunked-Encoded data”解决方案

    $s = curl_init(); curl_setopt($s, CURLOPT_POST, true); curl_setopt($s, CURLOPT_POSTFIELDS, $queryStr ...

  6. javascipt的【函数表达式】

    函数表达式 在编程时,我们可以看到不管是什么类库,jquery也好,zepto也好,都会用到大量的命名函数和匿名函数表达式,本节点就是为了弄懂为何会有这些函数表达式,以及在什么情况下会使用到这些表达式 ...

  7. 学记:为spring boot写一个自动配置

    spring boot遵循"约定优于配置"的原则,使用annotation对一些常规的配置项做默认配置,减少或不使用xml配置,让你的项目快速运行起来.spring boot的神奇 ...

  8. flex学习小结

    接触到flex一个多月了,今天做一个学习小结.如果有知识错误或者意见不同的地方.欢迎交流指教. 画外音:先说一下,我是怎么接触到flex布局的.对于正在学习的童鞋们,我建议大家没事可以逛逛网站,看看人 ...

  9. adb工具获取appPackage和appActivity

    1,手机连接电脑,打开手机调试功能,并运行待测试APP,终端执行: adb shell 2,接着,执行: dumpsys window windows | grep -E 'mFocusedApp' ...

  10. TableView 滑动收起键盘

    self.tableView.keyboardDismissMode = UIScrollViewKeyboardDismissModeOnDrag; 拖拽tableView就会收起键盘