検索
ホームページウェブフロントエンドhtmlチュートリアルWeb フロントエンド開発のためのブラウザ互換性 (継続的な更新)_html/css_WEB-ITnose

浏览器兼容性问题又被称为网页或网站兼容性问题;不同浏览器内核及所支持的html等网页语言标准不同,不同客户端环境(如分辨率不同)造成实际显示效果未能达到预期理想效果

首先我们来看一下目前市面上常见的一些浏览器:ie、chrome、firefox、safari、opera、maxthon、360、qq、yy、uc、sogou、2345、淘宝、猎豹、世界之窗等

其中表现很出色的有chrome、firefox、safari等;而表现极差的就是ie6/7内核浏览器了,我们的兼容性工作大半都是围绕这两个浏览器内核展开

我们的常规处理方式是调试各浏览器网页显示效果、使用成熟的前端开发框架、运用css与hack技巧等

 

常见hack技巧

css

_:ie6内核浏览器识别

color:#333;_color:#999;

*:ie7及其以下内核浏览器识别

color:#333;*color:#999;

\:如\9意为ie9及其以下内核浏览器识别

color:#333;color:#999\9;

!important:多内核浏览器识别,作用为强制此属性值

color:#333 !important;

 

html

ie内核浏览器识别

<!--[if IE]><![endif]-->

ie6内核浏览器识别

<!--[if IE 6]><![endif]-->

ie7及其以上内核浏览器识别

<!--[if gte IE 7]><![endif]-->

ie7及其以下内核浏览器识别

<!--[if lte IE 7]><![endif]-->

非ie内核浏览器识别

<!--[if !IE]><![endif]-->

非ie7及其以下内核浏览器识别

<!--[if !(lte IE 7)]><!-->

 

常见浏览器兼容性问题及解决方案

height低像素值无效

浏览器环境:ie6

height:5px;

height高度实际表现为大于5像素,问题产生是因为ie6下容器默认行高的影响;为高度过低元素添加溢出部分隐藏属性即可

height:5px;overflow:hidden;

 

margin值双倍边距

浏览器环境:ie6

margin:0 10px;float:left;

margin左右边距实际表现为20像素,问题一般发生于浮动元素,原因是ie6下浮动元素margin值默认变成双倍;为浮动元素添加行间元素属性即可,优化了同行元素的排版表现

margin:0 10px;display:inline;float:left;

或为浮动元素添加ie6专有属性

margin:0 10px;_margin:0 5px;float:left;

 

max-width、min-width、max-height、min-height等属性无效

浏览器环境:ie6

max-width:1280px;min-width:980px;max-height:800px;min-height:600px;

最大最小宽高属性在网页需要它出现时并没有给面子,问题原因是ie6不支持;解决办法是使用expression来实时获取元素当前适合宽高

max-width:1280px;_width:expression(documentElement.clientWidth > 1280 ? "1280px" : "auto");min-width:980px;_width:expression(documentElement.clientWidth < 980 ? "980px" : "auto");min-height:800px;_height:expression((documentElement.clientHeight || document.body.clientHeight) > 800 ? "800px" : "");min-height:600px;_height:expression((documentElement.clientHeight || document.body.clientHeight) < 600 ? "600px" : "");

网页实际情况各不相同,各位在根据需求处理具体页面时请自己提好裤子认真测试

 

fixed属性值无效

浏览器环境:ie6

position:fixed;top:100px;left:10px;

预想中的悬挂效果并没有出现,原因很简单ie6根本不支持;我们的解决办法是改变元素的悬挂为定位并使用expression来实时处理元素当前显示位置

position:fixed;_position:absolute;top:100px;_top:expression(documentElement.scrollTop + 100 + "px");left:10px;

expression工作时的表现还是可以接受,唯一的缺点是性能

 

定位元素上下或左右属性同时赋值时无效

浏览器环境:ie6

position:absolute;top:0;bottom:0;left:0;right:0;

画布实际表现为并没有按预想的全屏伸展开,问题产生原因是ie6下上下或左右定位属性同时存在时只识别上与左;为元素赋于宽高属性即可

width:100%;height:100%;position:absolute;top:0;left:0;

问题到此并没有得到完全解决,事实上,很多情况下,我们所希望的定位元素的宽高并非正好为100%

position:absolute;top:30px;bottom:50px;left:20px;right:20px;

这时css的能力似乎显得捉襟见肘,想拿出一个合适的宽高属性就无从下手了;我们只好通过css与js合作来处理

position:absolute;top:30px;left:20px;

var w = $(window).width() - 40;var h = $(window).height() - 80;$('#object').css({'width':w,'height':h});

有人问,resize时候不行了,你都知道网页resize了你还不知道resize事件捕捉到后怎么办么

 

透明png格式图片的背景问题

浏览器环境:ie6

网页上的糟糕表现为出现了灰背景,原因是ie6不支持png透明或png8及其以上的alpha透明度;网上的解决办法很多,javascript办法最多但都有通病,本身加载时间与之带来的网页负载,尤其是在网页本身负载就很大或网页上有过多需要处理的png图片的情况,会导致本来性能就不好的ie6浏览器明显停滞甚至崩溃,所以这里我们推荐的是css与图形处理两种纯天然处理方式,首先来看css滤镜处理

background:url(../images/logo.png) no-repeat 50%;_background:none;_filter:progid:DXImageTransform.Microsoft.AlphaImageLoader(src="../images/logo.png");

看上去一切都很美好,就是不能应用于img标签,其次是不能拼图所以也就不支持css sprite;我们再来看图形处理,使用工具为fireworks而非photoshop(其实是我们并不知它怎么实现同样操作),首先为打开的png图片的画布吸取图片四周最相近的背景色

然后打开图像预览,选择gif格式的索引色透明或alpha透明度导出,或选择png8格式的索引色透明导出即可;现在你们应该懂了,楼主不知道photoshop是否可以在图片导出时顺便附带上画布背景色

 

width等百分比值计算时有误

浏览器环境:ie6/7

width:25%;

如恰好有4个该元素充满外部容器,外容器宽度不是恰到好处时实际宽度会溢出,第4个元素会换行,问题的产生是因为ie6/7网页计算自适应处理能力不足;较为稳妥的处理方案是为ie6/7少许减少宽度

width:25%;*width:24%;

 

position属性使用过多或使用位置不恰当引起滚动时页面错乱

浏览器环境:ie7

position:relative;

网页上最直接表现就是极具破坏性的滚动错位,问题产生来自ie7自身渲染解析出错;这个问题的解决方案没有具体的代码,尽量避免在过多层级中使用该属性,绝对禁止为无需要无作用元素添加该属性,如tr、td等

 

容器内纯英文文本过长且无空格等符号时不能自动换行

浏览器环境:多浏览器

<p>abcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabcabc</p>

属于极端操作行为,问题来自各浏览器本身,添加2个word属性即可

word-break:break-all;word-wrap:break-word;

或者不换行,超出部分显示为更多

overflow:hidden;white-space:nowrap;text-overflow:ellipsis;

这2个办法各有优劣,使用时都需根据网页上具体情况而定

 

元素有margin上边距值且处于最前或下边距值且处于最后,外部容器高度不能自适应

浏览器环境:多浏览器

margin:20px 0 0;

外容器并没有按理想状况自适应撑开,从内间隙变成了外间隙,突出表现在外容器有背景色等特征可被明显观察时;根据情况更换元素或外容器的margin为padding

padding:20px 0 0;

 

老生常谈的清浮动

浏览器环境:多浏览器

问题没什么要描述的直接上解决代码

.clearfix:after{height:0;display:block;content:".";visibility:hidden;clear:both;}.clearfix{zoom:1;}.clear{height:0;overflow:hidden;font-size:0;clear:both;}

如使用清浮动样式的元素处于页面最底部,会给页面底部带来一小段空隙,发生该情况时需及时调整注意避免

 

悬挂元素工作时表现失常,页面滚动时有明显的停顿抖动

浏览器环境:多浏览器

position:fixed;

原本该吸附在页面上的元素并没有令人满意的工作,原因是网页带给浏览器的性能消耗过大如网页上有动画等;从苹果官网偷来的办法是添加一个叫做“隐藏被旋转元素背面”属性,观察结果很有效

position:fixed;-webkit-backface-visibility:hidden;-moz-backface-visibility:hidden;backface-visibility:hidden;

 

图片等元素不能自适应垂直居中

浏览器环境:多浏览器

<p><i><img  src=""    style="max-width:90%"  style="max-width:90%" / alt="Web フロントエンド開発のためのブラウザ互換性 (継続的な更新)_html/css_WEB-ITnose" ></i></p>

无需多描述直接上代码,p与img宽高均可任意改动

p{width:800px;height:800px;display:table-cell;text-align:center;vertical-align:middle;}p img{position:static;+position:relative;top:-50%;left:-50%;vertical-align:middle;}p i{position:static;+position:absolute;top:50%;}

 

一个网站尤其是大型门户网站的兼容性调试是一项很浩大的工程,耗时耗力耗青春,并且还不一定讨好,从事过大项目开发中兼容性调试的同行一定有着和他人不一样的体会,个中滋味实在难以明言

很多人以为自己懂兼容性,觉得不过如此,随手可以做出一个全浏览器兼容的网页

但是一个在兼容性问题上沉浸多年并在大型门户级网站开发中支持很久的人在兼容性水平的表现上是完全不一样的,兼容性出色的工程师可以通过部署好自己的代码,从很多源头上避免产生兼容性问题的可能性

 

現在の国内市場では、IE6/7 互換機能を適切に実行できる人材がますます少なくなっています。その理由は数多くあります。フロントエンド開発に参加する多くの新しい同僚は、特定の Web フロントエンド開発フレームワークに直接依存しています。フレームワーク自体の互換性条件 IE6/7 の互換性作業を回避することを選択し、古い世代のフロントエンド エンジニアが個人的な開発の一定の段階に達すると、他のより重要な機能やコンテンツに興味を持ちます。そして彼らは、将来性のないこのプロジェクトに取り組み続けるつもりはないでしょう。最後の最も重要な現実的な問題である、ie6/7 の長期サポートは、実際、その後のフロントエンド エンジニアの個人的な成長にとって非常にマイナスの要因となります。すべて、段階的に廃止されつつあり、その市場シェアはますます小さくなりつつあり、インターネット業界をリードする多くのメディアも、ie6 ユーザーを無視する姿勢を受け入れ始めています

声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
HTMLコードをどのように検証できますか?HTMLコードをどのように検証できますか?Apr 24, 2025 am 12:04 AM

HTMLコードは、オンラインバリデーター、統合ツール、自動化されたプロセスを使用するとクリーンになります。 1)w3cmarkupvalidationserviceを使用して、HTMLコードをオンラインで確認します。 2)リアルタイム検証のためにVisualStudiocodeにhtmlhint拡張機能をインストールして構成します。 3)HTMLTIDYを使用して、建設プロセスでHTMLファイルを自動的に検証およびクリーニングします。

HTML対CSSおよびJavaScript:Webテクノロジーの比較HTML対CSSおよびJavaScript:Webテクノロジーの比較Apr 23, 2025 am 12:05 AM

HTML、CSS、およびJavaScriptは、最新のWebページを構築するためのコアテクノロジーです。1。HTMLはWebページ構造を定義します。2。CSSはWebページの外観に責任があります。

マークアップ言語としてのHTML:その機能と目的マークアップ言語としてのHTML:その機能と目的Apr 22, 2025 am 12:02 AM

HTMLの機能は、Webページの構造とコンテンツを定義することであり、その目的は、情報を表示するための標準化された方法を提供することです。 1)HTMLは、タイトルやパラグラフなどのタグや属性を使用して、Webページのさまざまな部分を整理しています。 2)コンテンツとパフォーマンスの分離をサポートし、メンテナンス効率を向上させます。 3)HTMLは拡張可能であり、カスタムタグがSEOを強化できるようにします。

HTML、CSS、およびJavaScriptの未来:Web開発動向HTML、CSS、およびJavaScriptの未来:Web開発動向Apr 19, 2025 am 12:02 AM

HTMLの将来の傾向はセマンティクスとWebコンポーネントであり、CSSの将来の傾向はCSS-in-JSとCSShoudiniであり、JavaScriptの将来の傾向はWebAssemblyとServerLessです。 1。HTMLセマンティクスはアクセシビリティとSEO効果を改善し、Webコンポーネントは開発効率を向上させますが、ブラウザの互換性に注意を払う必要があります。 2。CSS-in-JSは、スタイル管理の柔軟性を高めますが、ファイルサイズを増やす可能性があります。 CSShoudiniは、CSSレンダリングの直接操作を可能にします。 3. Webassemblyブラウザーアプリケーションのパフォーマンスを最適化しますが、急な学習曲線があり、サーバーレスは開発を簡素化しますが、コールドスタートの問題の最適化が必要です。

HTML:構造、CSS:スタイル、JavaScript:動作HTML:構造、CSS:スタイル、JavaScript:動作Apr 18, 2025 am 12:09 AM

Web開発におけるHTML、CSS、およびJavaScriptの役割は次のとおりです。1。HTMLは、Webページ構造を定義し、2。CSSはWebページスタイルを制御し、3。JavaScriptは動的な動作を追加します。一緒に、彼らは最新のウェブサイトのフレームワーク、美学、および相互作用を構築します。

HTMLの未来:ウェブデザインの進化とトレンドHTMLの未来:ウェブデザインの進化とトレンドApr 17, 2025 am 12:12 AM

HTMLの将来は、無限の可能性に満ちています。 1)新機能と標準には、より多くのセマンティックタグとWebComponentsの人気が含まれます。 2)Webデザインのトレンドは、レスポンシブでアクセス可能なデザインに向けて発展し続けます。 3)パフォーマンスの最適化により、応答性の高い画像読み込みと怠zyなロードテクノロジーを通じてユーザーエクスペリエンスが向上します。

HTML対CSS対JavaScript:比較概要HTML対CSS対JavaScript:比較概要Apr 16, 2025 am 12:04 AM

Web開発におけるHTML、CSS、およびJavaScriptの役割は次のとおりです。HTMLはコンテンツ構造を担当し、CSSはスタイルを担当し、JavaScriptは動的な動作を担当します。 1。HTMLは、セマンティクスを確保するためにタグを使用してWebページの構造とコンテンツを定義します。 2。CSSは、セレクターと属性を介してWebページスタイルを制御して、美しく読みやすくします。 3。JavaScriptは、動的でインタラクティブな関数を実現するために、スクリプトを通じてWebページの動作を制御します。

HTML:それはプログラミング言語か何か他のものですか?HTML:それはプログラミング言語か何か他のものですか?Apr 15, 2025 am 12:13 AM

htmlisnotaprogramminglanguage; itisamarkuplanguage.1)htmlStructuresandformatswebcontentusingtags.2)ItworkswithcsssssssssdjavascriptforInteractivity、強化を促進します。

See all articles

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

Video Face Swap

Video Face Swap

完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

ホットツール

WebStorm Mac版

WebStorm Mac版

便利なJavaScript開発ツール

SublimeText3 Linux 新バージョン

SublimeText3 Linux 新バージョン

SublimeText3 Linux 最新バージョン

VSCode Windows 64 ビットのダウンロード

VSCode Windows 64 ビットのダウンロード

Microsoft によって発売された無料で強力な IDE エディター

MinGW - Minimalist GNU for Windows

MinGW - Minimalist GNU for Windows

このプロジェクトは osdn.net/projects/mingw に移行中です。引き続きそこでフォローしていただけます。 MinGW: GNU Compiler Collection (GCC) のネイティブ Windows ポートであり、ネイティブ Windows アプリケーションを構築するための自由に配布可能なインポート ライブラリとヘッダー ファイルであり、C99 機能をサポートする MSVC ランタイムの拡張機能が含まれています。すべての MinGW ソフトウェアは 64 ビット Windows プラットフォームで実行できます。

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター