HTML5規(guī)范畢竟是剛剛才定義完成的規(guī)范,還有一些瀏覽器并不能支持其中的新標(biāo)簽和新屬性,尤其是IE8及以下版本瀏覽器。下面給大家介紹處理HTML5新標(biāo)簽的瀏覽器兼容版問(wèn)題,需要的朋友參考下
HTML5規(guī)范畢竟是剛剛才定義完成的規(guī)范,還有一些瀏覽器并不能支持其中的新標(biāo)簽和新屬性,尤其是IE8及以下版本瀏覽器。以下介紹一些在頁(yè)面中使用HTML5新標(biāo)簽的實(shí)踐方法,目的是讓HTML5中的新標(biāo)簽在低級(jí)瀏覽器中也得到有限的支持,不至于影響整個(gè)的頁(yè)面功能。
-
讓瀏覽器識(shí)別HTML5規(guī)范中的新標(biāo)簽
IE8瀏覽器中還沒(méi)有添加對(duì)HTML5新標(biāo)簽的支持,所以在IE8中無(wú)法直接展現(xiàn)HTML5新標(biāo)簽中的內(nèi)容。慶幸的是IE8/IE7/IE6支持通過(guò)document.createElement方法產(chǎn)生的標(biāo)簽,可以利用這一特性讓這些瀏覽器支持HTML5新標(biāo)簽,代碼如下:
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]) }
瀏覽器支持新標(biāo)簽后,還需要添加標(biāo)簽?zāi)J(rèn)的樣式:
article,aside,figcaption,figure,footer,header,hgroup,nav,section{display:block} mark{background:#FF0;color:#000}
這樣兩段簡(jiǎn)單的JavaScript代碼和CSS代碼就可以讓IE8及以下版本瀏覽器支持HTML5中的新標(biāo)簽。當(dāng)然最好的方式是直接使用成熟的框架,目前有多個(gè)基于這一思想的框架,使用最多的是html5shim框架,html5shim的使用方法很簡(jiǎn)單,在頁(yè)面的head部分添加框架的引用即可:
<!--[if lt IE 9]> <script> src="http://html5shim.googlecode.com/svn/trunk/html5.js"</script> <![endif]-->
-
HTML5中新特性的向后兼容
廣義的HTML5,是包括了HTML5、CSS3以及新的API。因?yàn)樾绿匦曰蚨嗷蛏贂?huì)存在瀏覽器的兼容問(wèn)題,所以在使用新特性時(shí)檢測(cè)瀏覽器是否支持此特性是非常必要的。當(dāng)瀏覽器不支持新特性時(shí),可以做合適的向后兼容處理。目前,并沒(méi)有一個(gè)統(tǒng)一的方法檢測(cè)新特性的支持,有些新特性有對(duì)應(yīng)的API可以識(shí)別,有些新特性則只能通過(guò)一些技巧來(lái)識(shí)別。好在國(guó)外有熱心的工程師們開(kāi)發(fā)了多個(gè)檢測(cè)新特性的框架,其中檢測(cè)準(zhǔn)確率和使用率較高的是Modernizr。
Modernizr框架的原理是自動(dòng)檢測(cè)瀏覽器是否支持新特性,并在<html>標(biāo)簽上添加對(duì)應(yīng)的類(lèi)。如果瀏覽器支持某個(gè)特性,則會(huì)添加一個(gè)以特性名稱(chēng)命名的類(lèi),反之,則添加一個(gè)以“no-”為前綴加上特性名稱(chēng)命名的類(lèi)。同時(shí)也會(huì)生成一個(gè)名為modernizr的對(duì)象,通過(guò)判斷此對(duì)象上的代表各特性的屬性值,可以知道當(dāng)前瀏覽器是否支持此新特性。Modernizr框架同時(shí)也包含了html5shim框架的功能,即可以讓IE8及以下瀏覽器支持新標(biāo)簽。
Modernizr的使用方法很簡(jiǎn)單,首先在head部分引入框架的JavaScript文件:
<script src="js/modernizr.min.js"></script>
其次在html標(biāo)簽上添加一個(gè)名稱(chēng)為no-js的類(lèi):
<html class="no-js">
如果瀏覽器沒(méi)有禁用JavaScript,則瀏覽器加載頁(yè)面后,html標(biāo)簽上的類(lèi)會(huì)動(dòng)態(tài)替換和添加。加載后,html標(biāo)簽類(lèi)似如下:
<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代碼中,可以通過(guò)使用這些類(lèi)添加向后兼容代碼,如下是一個(gè)使用多背景圖的例子:
#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; }
對(duì)此框架感興趣的讀者,可以瀏覽Modernizr的官方網(wǎng)站,獲得更多更詳細(xì)的示例和使用方式。
-
音頻和視頻的兼容
音頻和視頻是在頁(yè)面中常用的多媒體標(biāo)簽,但瀏覽器兼容則是比較混亂,所以這里作為一個(gè)單獨(dú)的話題。音頻和視頻是比較早的得到瀏覽器原生支持的特性,讓音頻和視頻的播放不再限制于第三方的插件,尤其是在移動(dòng)平臺(tái)中。音頻和視頻是一塊大蛋糕,各瀏覽器廠商都想分得最大的那一塊,這也導(dǎo)致瀏覽器支持音頻和視頻的格式出現(xiàn)的分化。瀏覽器的支持音頻格式的列表如下:
瀏覽器 |
版本 |
支持格式 |
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>標(biāo)簽,但是并沒(méi)有一種統(tǒng)一的音頻格式。從支持的格式來(lái)看,要讓所有的瀏覽器可以播放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>標(biāo)簽 </audio>
視頻也有和音頻類(lèi)似的狀況,如下是瀏覽器支持視頻的格式列表:
瀏覽器 |
版本 |
支持格式 |
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 |
從瀏覽器支持的視頻格式來(lái)看,最佳的方式是提供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>
【相關(guān)推薦】
1. Html5免費(fèi)視頻教程
2. 通過(guò)phonegap操作數(shù)據(jù)庫(kù)的的教程詳解
3. H5中indexedDB 數(shù)據(jù)庫(kù)的使用方法詳解
4. 為什么現(xiàn)在HTML5的優(yōu)勢(shì)越來(lái)越大
5. 9和 午夜精品久久久内射近拍高清| 蜜臀亚洲AV无码精品国产午夜.| 亚洲精品无码久久久久sm| 精品国内自产拍在线视频| 四虎永久在线精品影院| 午夜福利麻豆国产精品| 精品国精品国产自在久国产应用 | 2021精品国产品免费观看| 国产l精品国产亚洲区在线观看| 国产啪精品视频网站| 久久亚洲av无码精品浪潮| 国产精品成人69XXX免费视频| 精品小视频在线观看| 日韩免费高清视频网站| 国产 日韩 中文字幕 制服| 国产伦精品一区二区三区免.费| 国产精品国产亚洲区艳妇糸列短篇 | 九九九国产精品成人免费视频| 日韩中文字幕一区| 日韩精品在线观看| 日韩电影免费观看| 亚洲AV日韩AV永久无码免下载| 国产91精品久久久久久| 国产成人久久精品亚洲小说| 国产精品久久久久久福利| 国产精品va一区二区三区| 国产自偷在线拍精品热| 国产精品麻豆免费版| 国产精品林美惠子在线观看| 国产精品无码专区在线播放| 国产真实伦偷精品| 视频一区视频二区日韩专区| 国产成人综合久久精品免费 | 精品久久国产视频| 在线观看麻豆精品国产不卡| 精品亚洲福利一区二区| 国产在线精品观看一区| 日韩亚洲一区二区三区| 日韩一区二区三区电影在线观看| 一级做a爰黑人又硬又粗免费看51社区国产精品视 | 国产伦精品一区二区三区免.费|