IE、FF、Safari、OP不同浏览器兼容报告

合集下载

对几款浏览器兼容性的测试分析

对几款浏览器兼容性的测试分析

对几款浏览器兼容性的测试分析摘要:浏览器(browser)是web系统中的核心构件,当前的主流浏览器包括ie、firefox、chrome、safari等。

这些常用浏览器对一般网页的兼容性各有不同,甚至同一种浏览器的不同版本对网页的兼容也不一样。

因此对主流浏览器的兼容性进行测试并分析出不兼容的主要原因,从而进一步提出相应的解决方法是网页设计人员面临的一项重要课题。

关键词:网页;兼容;浏览器;测试中图分类号:tp393.092 文献标识码:a 文章编号:1007-9599 (2012)18-0000-021 引言浏览器是web服务的客户端软件,它可以向web服务器发送各种请求,如http、ftp等,并对从服务器发来的超文本信息和各种媒体数据格式进行解释、显示和播放。

在当前互联网广泛渗入到人们工作、生活、娱乐等方方面面的今天,浏览器已成为人们上网时最常用的客户端程序。

浏览器主要是借助http协议与网站服务器的交互作用,而获取到网页,这些网页在http协议下是由url来指定的,这些网页的文件格式一般表示为html,并由mime在http协议中指明。

我们知道,一个网页中可以包括多个格式的文件或文档,且每个文件文档都是从服务器来分别获得的。

现在,大多数网站浏览器是能支持各种图像格式和文本格式的,例如除了支持html格式之外,还支持jpeg、png、gif等图像格式,并且能够扩展支持众多的网页插件(plug-ins),有的浏览器还支持url类型的格式,以及相关联的协议,例如https(http协议的加密版本)、ftp、gopher等。

在个人电脑上常用的网页浏览器,现在是越来越多样了,例如mozilla 的firefox、微软的internet explorer、apple的safari等,还有opera、google chrome、greenbrowser浏览器、360安全浏览器、搜狗浏览器、腾讯tt、傲游浏览器、百度浏览器等。

浏览器错误报告以及处理办法

浏览器错误报告以及处理办法

web前端培训教程:浏览器错误报告以及处理办法JavaScript 在错误处理调试上一直是它的软肋,如果脚本出错,给出的提示经常也让人摸不着头脑。

ECMAScript 第3 版为了解决这个问题引入了try...catch 和throw 语句以及一些错误类型,让开发人员更加适时的处理错误。

一.浏览器错误报告随着浏览器的不断升级,JavaScript 代码的调试能力也逐渐变强。

IE、Firefox、Safari、Chrome 和Opera 等浏览器,都具备报告JavaScript 错误的机制。

只不过,浏览器一般面向的是普通用户,默认情况下会隐藏此类信息。

IE:在默认情况下,左下角会出现错误报告,双击这个图标,可以看到错误消息对话框。

如果开启禁止脚本调试,那么出错的时候,会弹出错误调试框。

设置方法为:工具->InternetOptions 选项->高级->禁用脚本调试,取消勾选即可。

Firefox:在默认情况下,错误不会通过浏览器给出提示。

但在后台的错误控制台可以查看。

查看方法为:工具->[Web 开发者]->Web 控制台|错误控制台。

除了浏览器自带的,开发人员为Firefox 提供了一个强大的插件:Firebug。

它不但可以提示错误,还可以调试JavaScript和CSS、DOM、网络链接错误等。

Safari:在默认情况下,错误不会通过浏览器给出提示。

所以,我们需要开启它。

查看方法为:显示菜单栏->编辑->偏好设置->高级->在菜单栏中显示开发->显示Web 检查器|显示错误控制器。

Opera:在默认情况下,错误会被隐藏起来。

打开错误记录的方式为:显示菜单栏->查看->开发者工具->错误控制台。

Chrome:在默认情况下,错误会被隐藏起来。

打开错误记录的方法为:工具->JavaScript控制台。

二.错误处理良好的错误处理机制可以及时的提醒用户,知道发生了什么事,而不会惊慌失措。

兼容性测试报告跨平台和不同浏览器的一致性分析

兼容性测试报告跨平台和不同浏览器的一致性分析

兼容性测试报告跨平台和不同浏览器的一致性分析在当今数字化时代,互联网已成为人们日常生活中不可或缺的一部分。

随着用户使用不同的平台和浏览器访问网站的需求增加,保证网站的兼容性和一致性显得尤为重要。

本文将对跨平台和不同浏览器的兼容性进行测试和分析,通过测试报告呈现一致性的结果。

一、测试目的与方法1. 测试目的本次测试的主要目的是评估网站在各个操作系统平台和不同浏览器上的一致性。

通过测试,可以发现在不同平台和浏览器上存在的兼容性问题,为优化和改进网站的可用性提供参考依据。

2. 测试方法测试的主要方法包括以下几个步骤:a) 选择代表性的平台和浏览器:根据市场份额和用户群体,选择主流的操作系统平台如Windows、macOS、Linux,以及常用的浏览器如Chrome、Firefox、Safari、Edge等进行测试。

b) 设计测试用例:根据网站的功能和特点,设计一系列兼容性测试用例,包括网页布局、功能模块、响应式设计等方面的测试。

c) 执行测试用例:按照测试用例的设计执行测试,记录测试过程中的问题和异常现象。

d) 结果分析和报告编写:根据测试结果,分析问题的原因,并编写兼容性测试报告,提供一致性分析的结论和建议。

二、测试结果分析1. 跨平台一致性分析通过测试发现,在不同操作系统平台下,网站在大部分功能模块上表现一致。

然而,在某些特定功能上会存在一些差异。

以下是几个常见的跨平台兼容性问题:a) 字体显示:某些字体在不同平台下显示不一致,可能会导致页面排版混乱。

b) 图片加载:由于操作系统的差异,某些图片可能无法正常加载或出现变形。

c) 视频播放:不同平台对于视频格式支持不同,可能导致视频无法播放或音视频不同步。

2. 不同浏览器的一致性分析在测试过程中,我们主要关注了几种主流浏览器,包括Chrome、Firefox、Safari和Edge。

通过测试发现,不同浏览器对于网站的兼容性存在以下几个方面的不一致:a) CSS样式:不同浏览器对于CSS样式的解析存在差异,可能导致页面的显示效果不同。

不同浏览器兼容报告

不同浏览器兼容报告

Shuo de——中国金融数据及工具首席服务商IE、FF、Safari、OP不同浏览器兼容报告柯伯勋2011-03-08上海万得资讯科技有限公司Shanghai Wind Information Co., Ltd.地址: 上海浦东新区福山路33号建工大厦9楼邮编Zip : 200120电话T el : (8621)6886 2280传真Fax : (8621)6886 2281Email : sales@主页:1浏览器内核简介浏览器最重要或者说核心的部分是“Rendering Engine”,可大概译为“解释引擎”,不过我们一般习惯将之称为“浏览器内核”。

负责对网页语法的解释(如HTML、JavaScript)并渲染(显示)网页。

所以,通常所谓的浏览器内核也就是浏览器所采用的渲染引擎,渲染引擎决定了浏览器如何显示网页的内容以及页面的格式信息。

不同的浏览器内核对网页编写语法的解释也有不同,因此同一网页在不同的内核的浏览器里的渲染(显示)效果也可能不同,这也是网页编写者需要在不同内核的浏览器中测试网页显示效果的原因。

浏览器内核很多,如果加上所有的几乎没有什么人在用的非商业的免费内核,那么可能大约有10款以上甚至更多,不过通常我们比较常见的大约只有以下四种,下面先简单介绍一下。

1.1Trident:IE浏览器使用的内核,该内核程序在1997年的IE4中首次被采用,是微软在Mosaic代码的基础之上修改而来的,并沿用到目前的IE8。

Trident实际上是一款开放的内核,其接口内核设计的相当成熟,因此才有许多采用IE内核而非IE的浏览器涌现(如Maxthon、The World 、TT、GreenBrowser、AvantBrowser等)。

此外,为了方便也有很多人直接简称其为IE内核(当然也不排除有部分人是因为不知道内核名称而只好如此说)。

由于IE本身的“垄断性”(虽然名义上IE并非垄断,但实际上,特别是从Windows 95年代一直到XP初期,就市场占有率来说IE的确借助Windows的东风处于“垄断”的地位)而使得Trident内核的长期一家独大,微软很长时间都并没有更新Trident内核,这导致了两个后果——一是Trident内核曾经几乎与W3C标准脱节(2005年),二是Trident内核的大量Bug等安全性问题没有得到及时解决,然后加上一些致力于开源的开发者和一些学者们公开自己认为IE浏览器不安全的观点,也有很多用户转向了其他浏览器,Firefox和Opera就是这个时候兴起的。

浏览器不兼容原因及解决办法

浏览器不兼容原因及解决办法

1.文字本身的大小不兼容。

同样是font-size:14px的宋体文字,在不同浏览器下占的空间是不一样的,ie下实际占高16px,下留白3px,ff 下实际占高17px,上留白1px,下留白3px,opera下就更不一样了。

解决方案:给文字设定line-height。

确保所有文字都有默认的line-height 值。

这点很重要,在高度上我们不能容忍1px 的差异。

2.ff下容器高度限定,即容器定义了height之后,容器边框的外形就确定了,不会被内容撑大,而ie下是会被内容撑大,高度限定失效。

所以不要轻易给容器定义height。

3.还讨论内容撑破容器问题,横向上的。

如果float 容器未定义宽度,ff下内容会尽可能撑开容器宽度,ie下则会优先考虑内容折行。

故,内容可能撑破的浮动容器需要定义width。

小实验:有兴趣大家可以看看这段实验。

在不同浏览器下分别测试以下各项代码。

a.<div style=”border:1px solid red;height:10px”></div>b.<divstyle=”border:1px solid red;width:10px”></div>c.<div style=”border:1px solid red;float:left”></div>d.<div style=”border:1px solid red;overflow:hidden”></div>上面的代码在不同浏览器中是不一样的,实验起源于对小height 值div 的运用,<div style=”height:10px;overflow:hidden”></div>,小height 值要配合overflow:hidden一起使用。

实验好玩而已,想说明的是,浏览器对容器的边界解释是大不相同的,容器内容的影响结果各不相同。

兼容性测试报告

兼容性测试报告

兼容性测试报告浏览器兼容性问题是指由于不同的浏览器对相同的代码有不同的解释而导致页面显示不一致的情况。

原因:不同的浏览器使用不同的网页语言标准,例如内核所支持的HTML(标准通用标记语言下的应用程序);而不同的用户客户端环境(比如不同的分辨率)会导致显示效果无法达到预期的效果。

最常见的问题是web页面元素的混乱和错位。

内核:决定了浏览器如何显示网页的内容以及页面的格式信息。

常见的浏览器:IE浏览器(IE内核)、【Google/苹果浏览器(Webkit内核)】手机浏览器、火狐浏览器(Gecko内核)、Opera浏览器(Presto内核)详情可参考:百度统计流量研究院 /data/browser注:政府性质的浏览器只兼容IE浏览器常见介绍浏览器:IE、360、Firefox(特点兼容,跨多个操作系统)、Chrome(可以模拟各种手机进行测试,仅限于页面调整,并不能完整代替手机)、Safari(如果考虑苹果用户,需测试这个浏览器)小众浏览器:世界之窗、猎豹、遨游等等浏览器兼容性测试应用场景1.when,time1)用户要求,指定浏览器需求(环境:浏览器:IE8 、IE9 、火狐)2)网站一般都需要做兼容,从用户使用量,来选取主流浏览器2.兼容性测试内容:主要是页面的格式,字体,输入框,下拉框,复选框,按钮等的检查;页面显示在功能中检查常用的浏览器兼容性测试工具1.letester,可以测试不同版本的IE浏览器,2.在虚拟机里面安装不同版本的IE浏览器3. 这个网站可以支持不同系统不同版本浏览器的兼容性测试。

(免费时间较短)4.Spoon Browser Sandbox (需要安装插件,启动较慢)/browsers/面试中可能会问到的问题1.小众浏览器出现问题,需不需要做兼容性测试?用户反馈在小众浏览器上的问题?公司怎么处理?2.如果一个网站分为前台访问系统、后台管理系统;是否都需要做浏览器兼容性测试?作答:1)建议使用其他浏览器;看问题的严重程度或影响力(有可能会为了大头客户去专门做兼容)2)前台访问系统(用户)后台管理系统(公司内部或少数人,比如淘宝卖家),一般情况下,前台需要做,后台不需要兼容性测试,一般后台是兼容谷歌的前端——访问,后端——系统服务器测试计划包含“5W+1H”方便记忆目的(why)、测试范围(what)、测试进度安排(when)、测试人员(who)、测试环境(where)、测试方法/工具(how)、风险评估、培训计划。

Windows系统下各浏览器兼容性

Windows系统下各浏览器兼容性

Windows系统下各浏览器常用CSS HACK汇总表1. 此汇总表中测试浏览器的版本为:微软系统自带:IE6、 IE7、IE8火狐:Firefox 3.6.6Safari:Safari 5.0谷歌浏览器:Chrome 6.0.458.1 devOpera浏览器:Opera 10.602. 其中,多数CSS hack是在selector{property:value;}基础上更改的。

selector代表CSS选择器,property代表CSS特性,value代表特性的值。

3. FF代表Firefox,Ch代表Chorme,Sa代表Safari,Op代表Opera4. Q代表Quirks Mode,S代表Standards Mode。

5. Hack Type列的数字,指的是上面CSS hack的实现方式中的列表号。

1是指“利用浏览器对相同代码的解析和支持的不同实现的hack”,2是指以Firefox或Webkit特有的扩展样式实现的hack。

一定遵守CSS hack的三条原则。

CSS hack是没有办法的时候才使用的解决兼容性问题的招术,是用兼容性问题去解决兼容性问题,无异于饮鸩止渴。

切莫一有兼容性问题就使用,时刻记得改掉用CSS hack修补的问题。

IE6、IE7、IE8、Firefox兼容性CSS HACK代码+示例1.区别IE和非IE浏览器CSS HACK代码#divcss5{background:blue; /*非IE 背景藍色*/background:red \9; /*IE6、IE7、IE8背景紅色*/}2.区别IE6,IE7,IE8,FF CSS HACK【区别符号】:「\9」、「*」、「_」【示例】:#divcss5{background:blue; /*Firefox 背景变蓝色*/background:red \9; /*IE8 背景变红色*/*background:black; /*IE7 背景变黑色*/_background:orange; /*IE6 背景变橘色*/}【说明】:因为IE系列浏览器可读「\9」,而IE6和IE7可读「*」(米字号),另外IE6可辨识「_」(底线),因此可以依照顺序写下来,就会让浏览器正确的读取到自己看得懂得CSS语法,所以就可以有效区分IE各版本和非IE浏览器(像是Firefox、Opera、Google Chrome、Safari等)。

浏览器内核及对应兼容性的处理问题

浏览器内核及对应兼容性的处理问题

浏览器内核及对应兼容性的处理问题众所周知,目前市场上最火的五大浏览器是:google chrome、firefox(FF)、Internet Explorer(IE)、safari、opera。

他们相对应的内核是什么呢?谷歌浏览器:Google Chrome,谷歌浏览器之前一直使用苹果的webkit内核,但是现在它与苹果内核分道扬镳,自己开创了新的blink 内核,这个内核也在被欧鹏(opera浏览器)共同采用和开发;火狐浏览器:Mozilla Firefox ,内核是Gecko;opera浏览器:内核是blink;Safari浏览器:使用的是苹果公司自己的内核webkit;IE浏览器:微软出品的浏览器,IE4以上版本都是Trident内核。

由于垄断性,IE在很长一段时间内没有更新,导致两个后果:一是IE 与W3C标准脱节,二是Trident内核大量的bug问题没得到及时解决。

所以这就给了其他浏览器机会,比如firefox等。

也正是这些原因,使Web前端开发人员大费周折,特别是IE6正处在新旧交替的关键地方(已经逐渐被舍弃)。

当然除了这五大浏览器之外,市场上还有很多,例如:搜狗浏览器:兼容模式(IE:Trident)和高速模式(webkit);遨游浏览器:兼容模式(IE:Trident)和高速模式(webkit);QQ浏览器:普通模式(IE:Trident)和极速模式(webkit);360极速浏览器:基于谷歌(Chromium)和IE内核;360安全浏览器:IE内核。

当然,既然浏览器的内核不同,那么浏览器在解析代码的时候就会有可能不一样,因为他们所支持的方法有不同之处。

在pc端,通用的方法有三种:分别是能力检测、代理检测和怪癖检测。

1.能力检测(常用):通过获取标签的API,检测他是否支持这个API,如果支持,那么就用,否则就换另一种API来达到效果,例如原生js中常用的innerText方法:1// 书写innerText的兼容性代码:2// 获取标签的innerText(兼容所有浏览器)3function getInnerText(element) {4if (typeof element.innerT ext === "string") {5return element.innerT ext;6 } else {7return element.textContent;8 }9 }1011//设置标签的innerText(兼容所有浏览器)12function setInnerText(element, value) {13//能力检测14if (typeof element.innerText === "string") {15 element.innerText = value;16 } else {17 element.textContent = value;18 }19 }2.代理检测:通过在浏览器中的控制台(console.log)中输入erAgent,来获得浏览器的相关信息。

  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

1浏览器内核简介浏览器最重要或者说核心的部分是“Rendering Engine”,可大概译为“解释引擎”,不过我们一般习惯将之称为“浏览器内核”。

负责对网页语法的解释(如HTML、JavaScript)并渲染(显示)网页。

所以,通常所谓的浏览器内核也就是浏览器所采用的渲染引擎,渲染引擎决定了浏览器如何显示网页的内容以及页面的格式信息。

不同的浏览器内核对网页编写语法的解释也有不同,因此同一网页在不同的内核的浏览器里的渲染(显示)效果也可能不同,这也是网页编写者需要在不同内核的浏览器中测试网页显示效果的原因。

浏览器内核很多,如果加上所有的几乎没有什么人在用的非商业的免费内核,那么可能大约有10款以上甚至更多,不过通常我们比较常见的大约只有以下四种,下面先简单介绍一下。

1.1Trident:IE浏览器使用的内核,该内核程序在1997年的IE4中首次被采用,是微软在Mosaic代码的基础之上修改而来的,并沿用到目前的IE8。

Trident实际上是一款开放的内核,其接口内核设计的相当成熟,因此才有许多采用IE内核而非IE的浏览器涌现(如Maxthon、The World 、TT、GreenBrowser、AvantBrowser等)。

此外,为了方便也有很多人直接简称其为IE内核(当然也不排除有部分人是因为不知道内核名称而只好如此说)。

由于IE本身的“垄断性”(虽然名义上IE并非垄断,但实际上,特别是从Windows 95年代一直到XP初期,就市场占有率来说IE的确借助Windows的东风处于“垄断”的地位)而使得Trident内核的长期一家独大,微软很长时间都并没有更新Trident内核,这导致了两个后果——一是Trident内核曾经几乎与W3C标准脱节(2005年),二是Trident内核的大量Bug 等安全性问题没有得到及时解决,然后加上一些致力于开源的开发者和一些学者们公开自己认为IE浏览器不安全的观点,也有很多用户转向了其他浏览器,Firefox和Opera就是这个时候兴起的。

非Trident内核浏览器的市场占有率大幅提高也致使许多网页开发人员开始注意网页标准和非IE浏览器的浏览效果问题。

1.2Gecko:Netscape6开始采用的内核,后来的Mozilla FireFox也采用了该内核,Gecko的特点是代码完全公开,因此,其可开发程度很高,全世界的程序员都可以为其编写代码,增加功能。

因为这是个开源内核,因此受到许多人的青睐,Gecko内核的浏览器也很多,这也是Geckos 内核虽然年轻但市场占有率能够迅速提高的重要原因。

事实上,Gecko引擎的由来跟IE不无关系,前面说过IE没有使用W3C的标准,这导致了微软内部一些开发人员的不满;他们与当时已经停止更新了的Netscape的一些员工一起创办了Mozilla,以当时的Mosaic内核为基础重新编写内核,于是开发出了Geckos。

不过事实上,Gecko 内核的浏览器仍然还是Firefox用户最多,所以有时也会被称为Firefox内核。

此外Gecko也是一个跨平台内核,可以在Windows、BSD、Linux和Mac OS X中使用。

1.3Presto:目前Opera采用的内核,该内核在2003年的Opera7中首次被使用,该款引擎的特点就是渲染速度的优化达到了极致,也是目前公认网页浏览速度最快的浏览器内核,然而代价是牺牲了网页的兼容性。

实际上这是一个动态内核,与前面几个内核的最大的区别就在脚本处理上,Presto有着天生的优势,页面的全部或者部分都能够在回应脚本事件时等情况下被重新解析。

此外该内核在执行Javascrīpt的时候有着最快的速度,根据在同等条件下的测试,Presto内核执行同等Javascrīpt所需的时间仅有Trident和Gecko内核的约1/3(Trident内核最慢,不过两者相差没有多大)。

那次测试的时候因为Apple机的硬件条件和普通PC机不同所以没有测试WebCore内核。

只可惜Presto是商业引擎,使用Presto的除开Opera以外,只剩下NDSBrowser、Wii Internet Channle、Nokia 770网络浏览器等,这很大程度上限制了Presto 的发展。

1.4Webkit:苹果公司自己的内核,也是苹果的Safari浏览器使用的内核。

Webkit引擎包含WebCore 排版引擎及JavaScriptCore解析引擎,均是从KDE的KHTML及KJS引擎衍生而来,它们都是自由软件,在GPL条约下授权,同时支持BSD系统的开发。

所以Webkit也是自由软件,同时开放源代码。

在安全方面不受IE、Firefox的制约,所以Safari浏览器在国内还是很安全的。

限于Mac OS X的使用不广泛和Safari浏览器曾经只是Mac OS X的专属浏览器,这个内核本身应该说市场范围并不大;但似乎根据最新的浏览器调查表明,该浏览器的市场甚至已经超过了Opera的Presto了——当然这一方面得益于苹果转到x86架构之后的人气暴涨,另外也是因为Safari 3终于推出了Windows版的缘故吧。

Mac下还有OmniWeb、Shiira等人气很高的浏览器。

google的chrome也使用webkit作为内核。

WebKit 内核在手机上的应用也十分广泛,例如Google 的手机Gphone、Apple 的iPhone, Nokia’s Series 60 browser 等所使用的Browser 内核引擎,都是基于WebKit。

2Safari特点:Safari被称作世界上最快的浏览器。

但是,新发布的Safari 5从性能上来说已经远远超越了其上一个版本。

苹果公司称,Safari 5的运行速度要比Safari 4快30%,比Chrome 5.0快3%。

Safari 5的运行速度甚至是Firefox 3.6的2倍多。

增加了一个Reader(阅读器),取代了以往的RSS Reader。

与其他主流浏览器一样,也增加了一个默认搜索引擎的选项;包含了Safari 5开发工具。

其中有一个“web检查器”可以显示Safari与网站的整个交互过程;增强了对HTML5的支持:包括Geolocation、全屏幕HTML5视频、HTML5视频隐藏式字幕、新的分节元素(article、aside、footer、header、hgroup、nav和section)、HTML5 AJAX 历史记录、EventSource、WebSocket、HTML5可拖移属性、HTML5表格验证以及HTML5 Ruby。

Windows版本的Safari 5将支持GPU浏览加速。

这也是很多浏览器的新特征,可以达到更快的浏览速度;历史记录可以按照日期搜索了。

Safari 5采用Nitro JavaScript引擎。

Mac版Safari 5运行JavaScript脚本的速度比Safari 4快30%,比Chrome 5.0快3%,几乎达到火狐3.6的两倍。

2.1速度对比通过使用DNS预读取,以及改进的网页缓存技术,Safari 5可以更快地打开网页。

Safari 5的扩展应用得到沙箱技术的保护,从而提高了安全性和稳定性。

2.2CSS兼容能力对比2.3JavaScript兼容对比数值越小越好以上数据来源:/pingce/pingcenormal/0906/1678394.html3CSS区别及兼容3.1什么是CSS hack?由于不同的浏览器,比如IE6、IE7、IE8、Firefox等,对CSS的解析认识不一样,因此会导致生成的页面效果不一样,得不到我们所需要的页面效果。

这个时候我们就需要针对不同的浏览器去写不同的CSS,让它能够同时兼容不同的浏览器,能在不同的浏览器中也能得到我们想要的页面效果。

这个针对不同的浏览器写不同的CSS code的过程,就叫CSS hack,也叫写CSS hack。

不同的浏览器对CSS的解释都有一点出入,特别是padding, line-height这些要细微控制的地方,下面的hack基本可以解决这个问题:在属性前加下划线(_),那么此属性只会被IE6解释在属性前加星号(*),此属性只会被IE7解释在属性值后面加"\9",表示此属性只会被IE8解释3.2各浏览器CSS hack兼容表:整理二:IE6,IE7,FireFox,Opera,Safari兼容CSS的解决方法及CSS差别IE6,IE7,FireFox,Opera,Safari兼容CSS的解决方法及CSS差别有意思的测试地址: http://knb.im/css3/3.3CSS HACK以下两种方法几乎能解决现今所有HACK.1, !important随着IE7对!important的支持, !important 方法现在只针对IE6的HACK.(注意写法.记得该声明位置需要提前.)<style>#wrapper{width: 100px!important; /* IE7+FF */width: 80px; /* IE6 */}</style>2, IE6/IE7对FireFox*+html 与*html 是IE特有的标签, firefox 暂不支持.而*+html 又为IE7特有标签. <style>#wrapper{#wrapper { width: 120px; } /* FireFox */*html #wrapper { width: 80px;} /* ie6 fixed */*+html #wrapper { width: 60px;} /* ie7 fixed, 注意顺序*/}</style>注意:*+html 对IE7的HACK 必须保证HTML顶部有如下声明:<!DOCTYPE HTML PUBLIC “-//W3C//DTD HTML 4.01 Transitional//EN””/TR/html4/loose.dtd”>3.4 常见CSS兼容性问题div类1. 居中问题div里的内容,IE默认为居中,而FF默认为左对齐可以尝试增加代码margin:auto2. 高度问题两上下排列或嵌套的div,上面的div设置高度(height),如果div里的实际内容大于所设高度,在FF中会出现两个div重叠的现象;但在IE中,下面的div会自动给上面的div让出空间所以为避免出现层的重叠,高度一定要控制恰当,或者干脆不写高度,让他自动调节,比较好的方法是height:100%;但当这个div里面一级的元素都float了的时候,则需要在div块的最后,闭和前加一个沉底的空div,对应CSS是:.float_bottom{clear:both;height:0px;font-size:0px;padding:0;margin:0;border:0;line-height:0 px;overflow:hidden;}3. clear:both;不想受到float浮动的,就在div中写入clear:both;4. IE浮动margin 产生的双倍距离#box {float:left;width:100px;margin:0 0 0 100px; //这种情况之下IE会产生200px的距离display:inline; //使浮动忽略}5. padding 问题FF设置padding 后,div会增加height 和width,但IE不会(* 标准的XHTML1.0 定义dtd 好像一致了)高度控制恰当,或尝试使用height:100%;宽度减少使用padding但根据实际经验,一般FF和IE的padding 不会有太大区别,div 的实际宽= width + padding ,所以div写全width 和padding,width 用实际想要的宽减去padding 定义6. div嵌套时y 轴上padding 和marign 的问题FF里y 轴上子div 到父div 的距离为父padding + 子marignIE里y 轴上子div 到父div 的距离为父padding 和子marign 里大的一个FF里y 轴上父padding=0 且border=0 时,子div 到父div 的距离为0,子marign 作用到父div 外面7. padding,marign,height,width 的傻瓜式解决技巧注意是技巧,不是方法:写好标准头<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN""/TR/xhtml1/DTD/xhtml1-transitional.dtd"><html xmlns="/1999/xhtml">高尽量用padding,慎用margin,height尽量补上100%,父级height有定值子级height 不用100%,子级全为浮动时底部补个空clear:both的div宽尽量用margin,慎用padding,width算准实际要的减去padding列表类1. ul 标签在FF中默认是有padding 值的,而在IE中只有margin有值先定义ul {margin:0;padding:0;}2. ul和ol列表缩进问题消除ul、ol等列表的缩进时,样式应写成: {list-style:none;margin:0px;padding:0px;} 显示类1. display:block,inline 两个元素display:block; //可以为内嵌元素模拟为块元素display:inline; //实现同一行排列的的效果display:table; //for FF,模拟table的效果display:block 块元素,元素的特点是:总是在新行上开始;高度,行高以及顶和底边距都可控制;宽度缺省是它的容器的100%,除非设定一个宽度<div>,<p>,<h1>,<form>,<ul> 和<li> 是块元素的例子display:inline 就是将元素显示为行内元素,元素的特点是:和其他元素都在一行上;高,行高及顶和底边距不可改变;宽度就是它的文字或图片的宽度,不可改变。

相关文档
最新文档