国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > HTML > 正文

解決HTML5新標(biāo)簽的瀏覽器兼容性問題

2020-03-24 18:14:38
字體:
供稿:網(wǎng)友
HTML5規(guī)范畢竟是剛剛才定義完成的規(guī)范,還有一些瀏覽器并不能支持其中的新標(biāo)簽和新屬性,尤其是IE8及以下版本瀏覽器。下面給大家介紹處理HTML5新標(biāo)簽的瀏覽器兼容版問題,需要的朋友參考下

HTML5規(guī)范畢竟是剛剛才定義完成的規(guī)范,還有一些瀏覽器并不能支持其中的新標(biāo)簽和新屬性,尤其是IE8及以下版本瀏覽器。以下介紹一些在頁面中使用HTML5新標(biāo)簽的實(shí)踐方法,目的是讓HTML5中的新標(biāo)簽在低級(jí)瀏覽器中也得到有限的支持,不至于影響整個(gè)的頁面功能。

  • 讓瀏覽器識(shí)別HTML5規(guī)范中的新標(biāo)簽

IE8瀏覽器中還沒有添加對(duì)HTML5新標(biāo)簽的支持,所以在IE8中無法直接展現(xiàn)HTML5新標(biāo)簽中的內(nèi)容。慶幸的是IE8/IE7/IE6支持通過document.createElement方法產(chǎn)生的標(biāo)簽,可以利用這一特性讓這些瀏覽器支持HTML5新標(biāo)簽,代碼如下:

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])}

瀏覽器支持新標(biāo)簽后,還需要添加標(biāo)簽?zāi)J(rèn)的樣式:

article,aside,figcaption,figure,footer,header,hgroup,nav,section{display:block}mark{background:#FF0;color:#000}

這樣兩段簡(jiǎn)單的JavaScript代碼和CSS代碼就可以讓IE8及以下版本瀏覽器支持HTML5中的新標(biāo)簽。當(dāng)然最好的方式是直接使用成熟的框架,目前有多個(gè)基于這一思想的框架,使用最多的是html5shim框架,html5shim的使用方法很簡(jiǎn)單,在頁面的head部分添加框架的引用即可:

<!--[if lt IE 9]><script> src="http://html5shim.googlecode.com/svn/trunk/html5.js"</script><![endif]-->

  • HTML5中新特性的向后兼容

廣義的HTML5,是包括了HTML5、CSS3以及新的API。因?yàn)樾绿匦曰蚨嗷蛏贂?huì)存在瀏覽器的兼容問題,所以在使用新特性時(shí)檢測(cè)瀏覽器是否支持此特性是非常必要的。當(dāng)瀏覽器不支持新特性時(shí),可以做合適的向后兼容處理。目前,并沒有一個(gè)統(tǒng)一的方法檢測(cè)新特性的支持,有些新特性有對(duì)應(yīng)的API可以識(shí)別,有些新特性則只能通過一些技巧來識(shí)別。好在國外有熱心的工程師們開發(fā)了多個(gè)檢測(cè)新特性的框架,其中檢測(cè)準(zhǔn)確率和使用率較高的是Modernizr。

Modernizr框架的原理是自動(dòng)檢測(cè)瀏覽器是否支持新特性,并在<html>標(biāo)簽上添加對(duì)應(yīng)的類。如果瀏覽器支持某個(gè)特性,則會(huì)添加一個(gè)以特性名稱命名的類,反之,則添加一個(gè)以“no-”為前綴加上特性名稱命名的類。同時(shí)也會(huì)生成一個(gè)名為modernizr的對(duì)象,通過判斷此對(duì)象上的代表各特性的屬性值,可以知道當(dāng)前瀏覽器是否支持此新特性。Modernizr框架同時(shí)也包含了html5shim框架的功能,即可以讓IE8及以下瀏覽器支持新標(biāo)簽。

Modernizr的使用方法很簡(jiǎn)單,首先在head部分引入框架的JavaScript文件:

<script src="js/modernizr.min.js"></script>

其次在html標(biāo)簽上添加一個(gè)名稱為no-js的類:

<html class="no-js">

如果瀏覽器沒有禁用JavaScript,則瀏覽器加載頁面后,html標(biāo)簽上的類會(huì)動(dòng)態(tài)替換和添加。加載后,html標(biāo)簽類似如下:

<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代碼中,可以通過使用這些類添加向后兼容代碼,如下是一個(gè)使用多背景圖的例子:

#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;}

對(duì)此框架感興趣的讀者,可以瀏覽Modernizr的官方網(wǎng)站,獲得更多更詳細(xì)的示例和使用方式。

  • 音頻和視頻的兼容

音頻和視頻是在頁面中常用的多媒體標(biāo)簽,但瀏覽器兼容則是比較混亂,所以這里作為一個(gè)單獨(dú)的話題。音頻和視頻是比較早的得到瀏覽器原生支持的特性,讓音頻和視頻的播放不再限制于第三方的插件,尤其是在移動(dòng)平臺(tái)中。音頻和視頻是一塊大蛋糕,各瀏覽器廠商都想分得最大的那一塊,這也導(dǎo)致瀏覽器支持音頻和視頻的格式出現(xiàn)的分化。瀏覽器的支持音頻格式的列表如下:

鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標(biāo)記有誤,請(qǐng)第一時(shí)間聯(lián)系我們修改或刪除,多謝。

發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 襄樊市| 张家港市| 永宁县| 扎鲁特旗| 通州区| 甘孜| 收藏| 新建县| 织金县| 明光市| 乐昌市| 北川| 南昌市| 小金县| 尉犁县| 毕节市| 吉首市| 榆中县| 监利县| 宁夏| 双峰县| 铅山县| 永宁县| 石泉县| 榆林市| 乌兰县| 蒙阴县| 临夏县| 英德市| 睢宁县| 宁陕县| 仙桃市| 泸定县| 赣州市| 星座| 柳州市| 全南县| 牡丹江市| 溧阳市| 丰都县| 定襄县|