HTML5規範畢竟是剛剛才定義完成的規範,還有一些瀏覽器並不能支持其中的新標籤和新屬性,尤其是IE8及以下版本瀏覽器。以下介紹一些在頁面中使用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、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新標籤的瀏覽器兼容版問題,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對VeVb武林網網站的支持!