中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

如何解決HTML5新標簽的瀏覽器兼容性的問題

發布時間:2020-07-15 10:22:49 來源:億速云 閱讀:362 作者:Leah 欄目:web開發

今天就跟大家聊聊有關如何解決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框架的原理是自動檢測瀏覽器是否支持新特性,并在<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新標簽的瀏覽器兼容性的問題有進一步的了解嗎?如果還想了解更多知識或者相關內容,請關注億速云行業資訊頻道,感謝大家的支持。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

黔东| 台北县| 会东县| 台北市| 水富县| 剑川县| 河池市| 玉环县| 越西县| 积石山| 曲水县| 黄浦区| 伊通| 博野县| 枣阳市| 宜川县| 积石山| 应城市| 佛山市| 津市市| 宜城市| 姜堰市| 承德县| 天祝| 界首市| 忻州市| 安平县| 蓝田县| 寻乌县| 阳曲县| 大渡口区| 涡阳县| 黔东| 湘阴县| 安新县| 广安市| 新巴尔虎右旗| 阿瓦提县| 汝南县| 儋州市| 贡觉县|