首頁  >  文章  >  web前端  >  解決HTML5新標籤的瀏覽器相容性問題

解決HTML5新標籤的瀏覽器相容性問題

怪我咯
怪我咯原創
2017-04-30 11:00:105190瀏覽

HTML5規範畢竟是剛剛定義完成的規範,還有一些瀏覽器並不能支援其中的新標籤和新屬性,尤其是IE8及以下版本瀏覽器。以下為大家介紹處理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框架的原理是自動偵測瀏覽器是否支援新特性,並在100db36a723c770d327fc0aef2ce13b1標籤上新增對應的類別。如果瀏覽器支援某個特性,則會新增一個以特性名稱命名的類,反之,則會加上一個以「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 Explorer9.0+#

大约有80%的浏览器支持HTML5的b97864c2e0ef2353a16c4d64c7734e92标签,但是并没有一种统一的音频格式。从支持的格式来看,要让所有的浏览器可以播放audio元素上的音频,最佳的方式是提供MP3和Ogg两种格式,兼容代码如下:

<audio controls>
    <source src="elvis.mp3" type=&#39;audio/mpeg; codecs="mp3"&#39;>
    <source src="elvis.oga" type=&#39;audio/ogg; codecs="vorbis"&#39;>
    <!-- 向后兼容代码:如,显示提示信息、提供下载链接使用flash播放器等 -->
    浏览器不支持<code>audio</code>标签
</audio>

视频也有和音频类似的状况,如下是浏览器支持视频的格式列表:

瀏覽器

版本

支援格式

##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中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn