HTML5規範畢竟是剛剛定義完成的規範,還有一些瀏覽器並不能支援其中的新標籤和新屬性,尤其是IE8及以下版本瀏覽器。以下為大家介紹處理HTML5新標籤的瀏覽器相容版問題,需要的朋友參考下
HTML5規範畢竟是剛剛定義完成的規範,還有一些瀏覽器並不能支援其中的新標籤和新屬性,尤其是IE8及以下版本瀏覽器。以下介紹一些在頁面中使用HTML5新標籤的實踐方法,目的是讓HTML5中的新標籤在低階瀏覽器中也得到有限的支持,不至於影響整個的頁面功能。
讓瀏覽器辨識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中新功能的向後相容
#
<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 |
歌劇 | 10.0+ | Ogg Vorbis,WAV |
浏览器 |
版本 |
支持格式 |
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新標籤的瀏覽器相容性問題的詳細內容。更多資訊請關注PHP中文網其他相關文章!