目录
浏览器兼容性问题又被称为网页或网站兼容性问题;不同浏览器内核及所支持的html等网页语言标准不同,不同客户端环境(如分辨率不同)造成实际显示效果未能达到预期理想效果
常见hack技巧
css
html
常见浏览器兼容性问题及解决方案
height低像素值无效
margin值双倍边距
max-width、min-width、max-height、min-height等属性无效
fixed属性值无效
定位元素上下或左右属性同时赋值时无效
透明png格式图片的背景问题
width等百分比值计算时有误
position属性使用过多或使用位置不恰当引起滚动时页面错乱
容器内纯英文文本过长且无空格等符号时不能自动换行
元素有margin上边距值且处于最前或下边距值且处于最后,外部容器高度不能自适应
老生常谈的清浮动
悬挂元素工作时表现失常,页面滚动时有明显的停顿抖动
图片等元素不能自适应垂直居中
首页 web前端 html教程 web前端开发的浏览器兼容性(持续更新)_html/css_WEB-ITnose

web前端开发的浏览器兼容性(持续更新)_html/css_WEB-ITnose

Jun 24, 2016 am 11:51 AM

浏览器兼容性问题又被称为网页或网站兼容性问题;不同浏览器内核及所支持的html等网页语言标准不同,不同客户端环境(如分辨率不同)造成实际显示效果未能达到预期理想效果

首先我们来看一下目前市面上常见的一些浏览器:ie、chrome、firefox、safari、opera、maxthon、360、qq、yy、uc、sogou、2345、淘宝、猎豹、世界之窗等

其中表现很出色的有chrome、firefox、safari等;而表现极差的就是ie6/7内核浏览器了,我们的兼容性工作大半都是围绕这两个浏览器内核展开

我们的常规处理方式是调试各浏览器网页显示效果、使用成熟的前端开发框架、运用css与hack技巧等

 

常见hack技巧

css

_:ie6内核浏览器识别

color:#333;_color:#999;
登录后复制

*:ie7及其以下内核浏览器识别

color:#333;*color:#999;
登录后复制

\:如\9意为ie9及其以下内核浏览器识别

color:#333;color:#999\9;
登录后复制

!important:多内核浏览器识别,作用为强制此属性值

color:#333 !important;
登录后复制

html

ie内核浏览器识别

<!--[if IE]><![endif]-->
登录后复制

ie6内核浏览器识别

<!--[if IE 6]><![endif]-->
登录后复制

ie7及其以上内核浏览器识别

<!--[if gte IE 7]><![endif]-->
登录后复制

ie7及其以下内核浏览器识别

<!--[if lte IE 7]><![endif]-->
登录后复制

非ie内核浏览器识别

<!--[if !IE]><![endif]-->
登录后复制

非ie7及其以下内核浏览器识别

<!--[if !(lte IE 7)]><!-->
登录后复制

常见浏览器兼容性问题及解决方案

height低像素值无效

浏览器环境:ie6

height:5px;
登录后复制

height高度实际表现为大于5像素,问题产生是因为ie6下容器默认行高的影响;为高度过低元素添加溢出部分隐藏属性即可

height:5px;overflow:hidden;
登录后复制

margin值双倍边距

浏览器环境:ie6

margin:0 10px;float:left;
登录后复制

margin左右边距实际表现为20像素,问题一般发生于浮动元素,原因是ie6下浮动元素margin值默认变成双倍;为浮动元素添加行间元素属性即可,优化了同行元素的排版表现

margin:0 10px;display:inline;float:left;
登录后复制

或为浮动元素添加ie6专有属性

margin:0 10px;_margin:0 5px;float:left;
登录后复制

max-width、min-width、max-height、min-height等属性无效

浏览器环境:ie6

max-width:1280px;min-width:980px;max-height:800px;min-height:600px;
登录后复制

最大最小宽高属性在网页需要它出现时并没有给面子,问题原因是ie6不支持;解决办法是使用expression来实时获取元素当前适合宽高

max-width:1280px;_width:expression(documentElement.clientWidth > 1280 ? "1280px" : "auto");min-width:980px;_width:expression(documentElement.clientWidth < 980 ? "980px" : "auto");min-height:800px;_height:expression((documentElement.clientHeight || document.body.clientHeight) > 800 ? "800px" : "");min-height:600px;_height:expression((documentElement.clientHeight || document.body.clientHeight) < 600 ? "600px" : "");
登录后复制

网页实际情况各不相同,各位在根据需求处理具体页面时请自己提好裤子认真测试

fixed属性值无效

浏览器环境:ie6

position:fixed;top:100px;left:10px;
登录后复制

预想中的悬挂效果并没有出现,原因很简单ie6根本不支持;我们的解决办法是改变元素的悬挂为定位并使用expression来实时处理元素当前显示位置

position:fixed;_position:absolute;top:100px;_top:expression(documentElement.scrollTop + 100 + "px");left:10px;
登录后复制

expression工作时的表现还是可以接受,唯一的缺点是性能

定位元素上下或左右属性同时赋值时无效

浏览器环境:ie6

position:absolute;top:0;bottom:0;left:0;right:0;
登录后复制

画布实际表现为并没有按预想的全屏伸展开,问题产生原因是ie6下上下或左右定位属性同时存在时只识别上与左;为元素赋于宽高属性即可

width:100%;height:100%;position:absolute;top:0;left:0;
登录后复制

问题到此并没有得到完全解决,事实上,很多情况下,我们所希望的定位元素的宽高并非正好为100%

position:absolute;top:30px;bottom:50px;left:20px;right:20px;
登录后复制

这时css的能力似乎显得捉襟见肘,想拿出一个合适的宽高属性就无从下手了;我们只好通过css与js合作来处理

position:absolute;top:30px;left:20px;
登录后复制

var w = $(window).width() - 40;var h = $(window).height() - 80;$('#object').css({'width':w,'height':h});
登录后复制

有人问,resize时候不行了,你都知道网页resize了你还不知道resize事件捕捉到后怎么办么

透明png格式图片的背景问题

浏览器环境:ie6

网页上的糟糕表现为出现了灰背景,原因是ie6不支持png透明或png8及其以上的alpha透明度;网上的解决办法很多,javascript办法最多但都有通病,本身加载时间与之带来的网页负载,尤其是在网页本身负载就很大或网页上有过多需要处理的png图片的情况,会导致本来性能就不好的ie6浏览器明显停滞甚至崩溃,所以这里我们推荐的是css与图形处理两种纯天然处理方式,首先来看css滤镜处理

background:url(../images/logo.png) no-repeat 50%;_background:none;_filter:progid:DXImageTransform.Microsoft.AlphaImageLoader(src="../images/logo.png");
登录后复制

看上去一切都很美好,就是不能应用于img标签,其次是不能拼图所以也就不支持css sprite;我们再来看图形处理,使用工具为fireworks而非photoshop(其实是我们并不知它怎么实现同样操作),首先为打开的png图片的画布吸取图片四周最相近的背景色

然后打开图像预览,选择gif格式的索引色透明或alpha透明度导出,或选择png8格式的索引色透明导出即可;现在你们应该懂了,楼主不知道photoshop是否可以在图片导出时顺便附带上画布背景色

width等百分比值计算时有误

浏览器环境:ie6/7

width:25%;
登录后复制

如恰好有4个该元素充满外部容器,外容器宽度不是恰到好处时实际宽度会溢出,第4个元素会换行,问题的产生是因为ie6/7网页计算自适应处理能力不足;较为稳妥的处理方案是为ie6/7少许减少宽度

width:25%;*width:24%;
登录后复制

position属性使用过多或使用位置不恰当引起滚动时页面错乱

浏览器环境:ie7

position:relative;
登录后复制

网页上最直接表现就是极具破坏性的滚动错位,问题产生来自ie7自身渲染解析出错;这个问题的解决方案没有具体的代码,尽量避免在过多层级中使用该属性,绝对禁止为无需要无作用元素添加该属性,如tr、td等

容器内纯英文文本过长且无空格等符号时不能自动换行

浏览器环境:多浏览器

<p>abcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabc</p>
登录后复制

属于极端操作行为,问题来自各浏览器本身,添加2个word属性即可

word-break:break-all;word-wrap:break-word;
登录后复制

或者不换行,超出部分显示为更多

overflow:hidden;white-space:nowrap;text-overflow:ellipsis;
登录后复制

这2个办法各有优劣,使用时都需根据网页上具体情况而定

元素有margin上边距值且处于最前或下边距值且处于最后,外部容器高度不能自适应

浏览器环境:多浏览器

margin:20px 0 0;
登录后复制

外容器并没有按理想状况自适应撑开,从内间隙变成了外间隙,突出表现在外容器有背景色等特征可被明显观察时;根据情况更换元素或外容器的margin为padding

padding:20px 0 0;
登录后复制

老生常谈的清浮动

浏览器环境:多浏览器

问题没什么要描述的直接上解决代码

.clearfix:after{height:0;display:block;content:".";visibility:hidden;clear:both;}.clearfix{zoom:1;}.clear{height:0;overflow:hidden;font-size:0;clear:both;}
登录后复制

如使用清浮动样式的元素处于页面最底部,会给页面底部带来一小段空隙,发生该情况时需及时调整注意避免

悬挂元素工作时表现失常,页面滚动时有明显的停顿抖动

浏览器环境:多浏览器

position:fixed;
登录后复制

原本该吸附在页面上的元素并没有令人满意的工作,原因是网页带给浏览器的性能消耗过大如网页上有动画等;从苹果官网偷来的办法是添加一个叫做“隐藏被旋转元素背面”属性,观察结果很有效

position:fixed;-webkit-backface-visibility:hidden;-moz-backface-visibility:hidden;backface-visibility:hidden;
登录后复制

图片等元素不能自适应垂直居中

浏览器环境:多浏览器

<p><i><img  src=""    style="max-width:90%"  style="max-width:90%" / alt="web前端开发的浏览器兼容性(持续更新)_html/css_WEB-ITnose" ></i></p>
登录后复制

无需多描述直接上代码,p与img宽高均可任意改动

p{width:800px;height:800px;display:table-cell;text-align:center;vertical-align:middle;}p img{position:static;+position:relative;top:-50%;left:-50%;vertical-align:middle;}p i{position:static;+position:absolute;top:50%;}
登录后复制

 

一个网站尤其是大型门户网站的兼容性调试是一项很浩大的工程,耗时耗力耗青春,并且还不一定讨好,从事过大项目开发中兼容性调试的同行一定有着和他人不一样的体会,个中滋味实在难以明言

很多人以为自己懂兼容性,觉得不过如此,随手可以做出一个全浏览器兼容的网页

但是一个在兼容性问题上沉浸多年并在大型门户级网站开发中支持很久的人在兼容性水平的表现上是完全不一样的,兼容性出色的工程师可以通过部署好自己的代码,从很多源头上避免产生兼容性问题的可能性

 

现在的国内市场上,能出色完成ie6/7兼容性工作的人越来越少,原因有很多:很多新加入前端开发的同行,直接依托某web前端开发框架,并且在框架本身的兼容性条件下选择回避ie6/7的兼容性工作;而老一辈前端工程师随着个人发展到一定阶段后,有着其它更重要的职能与个人更感兴趣的内容,也不会乐意继续从事该项没有未来的工作;最后一个重中之重的现实问题,长期支持ie6/7对于前端工程师的个人成长来说的确是一个很不利的因素,毕竟它正处于淘汰进行时,市场占有量越来越少并且很多引领互联网行业的媒体也开始接受忽略来自ie6用户的态度

本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

Video Face Swap

Video Face Swap

使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

HTML容易为初学者学习吗? HTML容易为初学者学习吗? Apr 07, 2025 am 12:11 AM

HTML适合初学者学习,因为它简单易学且能快速看到成果。1)HTML的学习曲线平缓,易于上手。2)只需掌握基本标签即可开始创建网页。3)灵活性高,可与CSS和JavaScript结合使用。4)丰富的学习资源和现代工具支持学习过程。

HTML,CSS和JavaScript的角色:核心职责 HTML,CSS和JavaScript的角色:核心职责 Apr 08, 2025 pm 07:05 PM

HTML定义网页结构,CSS负责样式和布局,JavaScript赋予动态交互。三者在网页开发中各司其职,共同构建丰富多彩的网站。

HTML中起始标签的示例是什么? HTML中起始标签的示例是什么? Apr 06, 2025 am 12:04 AM

AnexampleOfAstartingTaginHtmlis,beginSaparagraph.startingTagSareEssentialInhtmlastheyInitiateEllements,defiteTheeTheErtypes,andarecrucialforsstructuringwebpages wepages webpages andConstructingthedom。

了解HTML,CSS和JavaScript:初学者指南 了解HTML,CSS和JavaScript:初学者指南 Apr 12, 2025 am 12:02 AM

WebDevelovermentReliesonHtml,CSS和JavaScript:1)HTMLStructuresContent,2)CSSStyleSIT和3)JavaScriptAddSstractivity,形成thebasisofmodernWebemodernWebExexperiences。

网页批注如何实现Y轴位置的自适应布局? 网页批注如何实现Y轴位置的自适应布局? Apr 04, 2025 pm 11:30 PM

网页批注功能的Y轴位置自适应算法本文将探讨如何实现类似Word文档的批注功能,特别是如何处理批注之间的间�...

Gitee Pages静态网站部署失败:单个文件404错误如何排查和解决? Gitee Pages静态网站部署失败:单个文件404错误如何排查和解决? Apr 04, 2025 pm 11:54 PM

GiteePages静态网站部署失败:404错误排查与解决在使用Gitee...

HTML,CSS和JavaScript:Web开发人员的基本工具 HTML,CSS和JavaScript:Web开发人员的基本工具 Apr 09, 2025 am 12:12 AM

HTML、CSS和JavaScript是Web开发的三大支柱。1.HTML定义网页结构,使用标签如、等。2.CSS控制网页样式,使用选择器和属性如color、font-size等。3.JavaScript实现动态效果和交互,通过事件监听和DOM操作。

如何用CSS3和JavaScript实现图片点击后周围图片散开并放大效果? 如何用CSS3和JavaScript实现图片点击后周围图片散开并放大效果? Apr 05, 2025 am 06:15 AM

实现图片点击后周围图片散开并放大效果许多网页设计中,需要实现一种交互效果:点击某张图片,使其周围的...

See all articles