【HTML5】如何处理HTML5新标签的浏览器兼容版问…
2018-06-24 01:04:28来源:未知 阅读 ()
原文地址:http://www.dang-jian.com/?p=196
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文件:
?1<
script
src
=
"js/modernizr.min.js"
></
script
>
其次在html标签上添加一个名称为no-js的类:
?1<
html
class
=
"no-js"
>
-
如果浏览器没有禁用JavaScript,则浏览器加载页面后,html标签上的类会动态替换和添加。加载后,html标签类似如下:
?1<
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代码中,可以通过使用这些类添加向后兼容代码,如下是一个使用多背景图的例子:
?1234567#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两种格式,兼容代码如下:
?123456<
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两种格式的视频。兼容代码如下:
?123456<
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
>
标签:
版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有
上一篇:css常用样式
下一篇:wap问答系统工作总结
- ie8下透明度处理 2020-06-11
- 如果是自学WEB前端的话,该如何才能找到一份7K实习生工作呢 2020-06-04
- 前端如何学习? 2020-06-04
- 如何成为一名优秀的web前端工程师 2020-06-02
- 零基础小白转行如何入门学习web前端 2020-06-01
IDC资讯: 主机资讯 注册资讯 托管资讯 vps资讯 网站建设
网站运营: 建站经验 策划盈利 搜索优化 网站推广 免费资源
网络编程: Asp.Net编程 Asp编程 Php编程 Xml编程 Access Mssql Mysql 其它
服务器技术: Web服务器 Ftp服务器 Mail服务器 Dns服务器 安全防护
软件技巧: 其它软件 Word Excel Powerpoint Ghost Vista QQ空间 QQ FlashGet 迅雷
网页制作: FrontPages Dreamweaver Javascript css photoshop fireworks Flash