【HTML5】如何處理HTML5新標籤的瀏覽器安全色版問題

來源:互聯網
上載者:User

標籤:通過   add   length   foo   第三方   lis   移動平台   瀏覽器安全色   htm   

  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 <scriptsrc="js/modernizr.min.js"></script>

  其次在html標籤上添加一個名稱為no-js的類:

 
1 <htmlclass="no-js">

  如果瀏覽器沒有禁用JavaScript,則瀏覽器載入頁面後,html標籤上的類會動態替換和添加。載入後,html標籤類似如下:

 
1 <htmlclass="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) topleftrepeat-x;}.multiplebgs #nice {    background: url(background-one.png) topleftrepeat-x,url(background-two.png) bottomleftrepeat-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 <audiocontrols>    <sourcesrc="elvis.mp3"type=‘audio/mpeg; codecs="mp3"‘>    <sourcesrc="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 <videocontrols>        <sourcesrc=video.webm type=video/webm>        <sourcesrc=video.mp4 type=video/mp4>          <!—向後相容代碼: -->          <iframewidth="480"height="360"src="http://www.youtube.com/embed/xzMUyqmaqcw?rel=0"frameborder="0"allowfullscreen></iframe</video>

 

    轉載原文http://www.cnblogs.com/HDK2016/p/6540112.html

【HTML5】如何處理HTML5新標籤的瀏覽器安全色版問題

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.