ホームページ > 記事 > ウェブフロントエンド > H5 の新しいタブ ブラウザの互換性の問題
今回は、H5 新しいタブ ブラウザの互換性問題について説明します。H5 新しいタブ ブラウザの互換性問題に対処する際の 注意事項 は何ですか? 以下は実際的なケースです。
結局のところ、HTML5 仕様はまだ定義されたばかりの仕様であり、特に IE8 以下のブラウザでは、新しいタグや新しい属性をサポートできないブラウザがいくつかあります。以下では、ページ内で HTML5 の新しいタグを使用するためのいくつかの実用的な方法を紹介します。その目的は、HTML5 の新しいタグが低レベルのブラウザーで限定的にサポートされ、ページ全体の機能に影響を及ぼさないようにすることです。HTML5仕様の新しいタグをブラウザに認識させます
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}このように、
<!--[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">If JavaScript isブラウザで無効になっていない場合、ブラウザがページをロードした後、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 の公式 Web サイトを参照して、より詳細な例と使用法を確認できます。
オーディオとビデオの互換性
ブラウザ |
バージョン |
サポートされている形式 |
Internet Explorer |
9.0+ |
MP 3、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 |
大约有80%的浏览器支持HTML5的
<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>
相信看了本文案例你已经掌握了方法,更多精彩请关注php中文网其它相关文章!
推荐阅读:
spring mvc+localResizeIMG实现H5端图片压缩上传
以上がH5 の新しいタブ ブラウザの互換性の問題の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。