处理HTML5新标签的浏览器兼容版问题
html5规范毕竟是刚刚才定义完成的规范,还有一些浏览器并不能支持其中的新标签和新属性,尤其是ie8及以下版本浏览器。以下介绍一些在页面中使用html5新标签的实践方法,目的是让html5中的新标签在低级浏览器中也得到有限的支持,不至于影响整个的页面功能。
- 让浏览器识别html5规范中的新标签
ie8浏览器中还没有添加对html5新标签的支持,所以在ie8中无法直接展现html5新标签中的内容。庆幸的是ie8/ie7/ie6支持通过document.createelement方法产生的标签,可以利用这一特性让这些浏览器支持html5新标签,代码如下:
var e = "abbr, article, aside, audio, canvas, datalist, details, dialog, eventsource, figure, footer, header, hgroup, mark, menu, meter, nav, output, progress, section, time, video".split(', '); var i= e.length; while (i--){ document.createelement(e[i]) }
浏览器支持新标签后,还需要添加标签默认的样式:
article,aside,figcaption,figure,footer,header,hgroup,nav,section{display:block} mark{background:#ff0;color:#000}
这样两段简单的javascript代码和css代码就可以让ie8及以下版本浏览器支持html5中的新标签。当然最好的方式是直接使用成熟的框架,目前有多个基于这一思想的框架,使用最多的是html5shim框架,html5shim的使用方法很简单,在页面的head部分添加框架的引用即可:
<!--[if lt ie 9]> <script> src="http://html5shim.googlecode.com/svn/trunk/html5.js"</script> <![endif]-->
- html5中新特性的向后兼容
广义的html5,是包括了html5、css3以及新的api。因为新特性或多或少会存在浏览器的兼容问题,所以在使用新特性时检测浏览器是否支持此特性是非常必要的。当浏览器不支持新特性时,可以做合适的向后兼容处理。目前,并没有一个统一的方法检测新特性的支持,有些新特性有对应的api可以识别,有些新特性则只能通过一些技巧来识别。好在国外有热心的工程师们开发了多个检测新特性的框架,其中检测准确率和使用率较高的是modernizr。
modernizr框架的原理是自动检测浏览器是否支持新特性,并在<html>标签上添加对应的类。如果浏览器支持某个特性,则会添加一个以特性名称命名的类,反之,则添加一个以“no-”为前缀加上特性名称命名的类。同时也会生成一个名为modernizr的对象,通过判断此对象上的代表各特性的属性值,可以知道当前浏览器是否支持此新特性。modernizr框架同时也包含了html5shim框架的功能,即可以让ie8及以下浏览器支持新标签。
modernizr的使用方法很简单,首先在head部分引入框架的javascript文件:
<script src="js/modernizr.min.js"></script>
其次在html标签上添加一个名称为no-js的类:
<html class="no-js">
如果浏览器没有禁用javascript,则浏览器加载页面后,html标签上的类会动态替换和添加。加载后,html标签类似如下:
<html class="js canvas canvastext geolocation rgba hsla no-multiplebgs borderimage borderradius boxshadow opacity no-cssanimations csscolumns no-cssgradients no-cssreflections csstransforms no-csstransforms3d no-csstransitions video audio cufon-active fontface cufon-ready">
在css代码中,可以通过使用这些类添加向后兼容代码,如下是一个使用多背景图的例子:
#nice { background: url(background-one.png) top left repeat-x; } .multiplebgs #nice { background: url(background-one.png) top left repeat-x,url(background-two.png) bottom left repeat-x; }
对此框架感兴趣的读者,可以浏览modernizr的官方网站,获得更多更详细的示例和使用方式。
-
音频和视频的兼容
音频和视频是在页面中常用的多媒体标签,但浏览器兼容则是比较混乱,所以这里作为一个单独的话题。音频和视频是比较早的得到浏览器原生支持的特性,让音频和视频的播放不再限制于第三方的插件,尤其是在移动平台中。音频和视频是一块大蛋糕,各浏览器厂商都想分得最大的那一块,这也导致浏览器支持音频和视频的格式出现的分化。浏览器的支持音频格式的列表如下:
浏览器 |
版本 |
支持格式 |
internet explorer |
9.0+ |
mp3, aac |
chrome |
6.0+ |
ogg vorbis, mp3, wav(9.0+) |
firefox |
3.6+ |
ogg vorbis, wav |
safari |
5.0+ |
mp3, aac, wav |
opera |
10.0+ |
ogg vorbis, wav |
大约有80%的浏览器支持html5的<audio>标签,但是并没有一种统一的音频格式。从支持的格式来看,要让所有的浏览器可以播放audio元素上的音频,最佳的方式是提供mp3和ogg两种格式,兼容代码如下:
<audio controls> <source src="elvis.mp3" type='audio/mpeg; codecs="mp3"'> <source src="elvis.oga" type='audio/ogg; codecs="vorbis"'> <!-- 向后兼容代码:如,显示提示信息、提供下载链接使用flash播放器等 --> 浏览器不支持<code>audio</code>标签 </audio>
视频也有和音频类似的状况,如下是浏览器支持视频的格式列表:
浏览器 |
版本 |
支持格式 |
internet explorer |
9.0+ |
mp4 |
chrome |
6.0+ |
mp4,webm,ogg |
firefox |
3.6+ |
webm,ogg |
safari |
5.0+ |
mp4 |
opera |
10.0+ |
webm,ogg |
从浏览器支持的视频格式来看,最佳的方式是提供webm和mp4两种格式的视频。兼容代码如下:
<video controls> <source src=video.webm type=video/webm> <source src=video.mp4 type=video/mp4> <!—向后兼容代码: --> <iframe width="480" height="360" src="http://www.youtube.com/embed/xzmuyqmaqcw?rel=0" frameborder="0" allowfullscreen></iframe> </video>
以上所述是小编给大家介绍的处理html5新标签的浏览器兼容版问题,希望对大家有所帮助
推荐阅读
-
HTML5新标签兼容——> 的两种方法
-
关于HTML5 Placeholder新标签低版本浏览器下不兼容的问题分析及解决办法
-
html5\CSS3有哪些新特性、移除了哪些元素?如何处理HTML5新标签的浏览器兼容问题?如何区分HTML和HTML5?
-
html5那些新特性,移除了哪些元素?如何处理html5的兼容性问题?如何区分html和html5?
-
关于老式浏览器兼容HTML5和CSS3的问题
-
处理HTML5新标签的浏览器兼容版问题
-
HTML5有哪些新特性,移除了哪些元素?如何处理HTML5新标签的浏览器兼容性问题?如何区分HTML和HTML5?
-
不同浏览器对于html5 audio标签和音频格式的兼容性
-
处理HTML5新标签的浏览器兼容版问题
-
HTML5新标签兼容——> 的两种方法