瀏覽器兼容性
瀏覽器兼容的重要性
- 網站做好了瀏覽器兼容,能夠讓網站在不同的瀏覽器下都正常顯示
- 瀏覽器兼容能夠抓住更多的網站訪客
- 瀏覽器兼容能夠給客戶更好的體驗
瀏覽器大戰
在Internet Explorer和Netscape Navigator的爭戰中,兩個瀏覽器各自推出非標準的HTML語句(如Navigator的BLINK標籤——閃爍效果,Internet Explorer的MARQUEE標籤——跑馬燈效果),以專有的特色功能分割市場。微軟以此產品差異化策略(Product Differentation)成功開發了一群忠實客戶和數量上有一定影響的IE Only網站。
同時,網頁瀏覽標準只規定了接口,並沒有接口實現的詳細規範,使得各瀏覽器對相同的功能使用了不同的實現方法,並導致了功能實現的差異。這些差異按程度由顯示方面到核心概念的都存在。瀏覽器兼容性就是指標準功能在各瀏覽器的差異程度,差異的解決方法是為瀏覽器兼容。
兼容趨勢
- 瀏覽器大戰後期的Internet Explorer和Netscape Navigator兩大瀏覽器都支持HTML 4.0和CSS 1,使得許多專用語法失去意義而被廢止。
- 客戶端腳本方面,瀏覽器大戰的產物DOM變成了瀏覽器間操控技術的共同界面;對專有方法已有涵蓋。
- 瀏覽器市場擴大,網站為了宣稱自己的兼容能力,一般都能在Mozilla Firefox、Opera、Safari和傳統陣營的Internet Explorer、Netscape Navigator正常被瀏覽。
- 瀏覽器的兼容能力日益受到需要;瀏覽器亦因應趨勢,使自己的瀏覽器提供更多兼容功能。
指標
網頁的瀏覽器兼容的總體目標是在各瀏覽器中顯示正常,實現跨瀏覽器的,符合用戶體驗的高質量的網站。
一般從以下幾個方面考慮網頁的瀏覽器兼容性:
解決方法
- Hack
- css屬性Hack
- 選擇器Hack
- 條件注釋
具瀏覽器兼容性的網頁編碼方式
下面是HTML和JavaScript的例子:
<div id="sample" style="position: absolute; top: 100px; left: 100px;">測試文字</div>
以上代碼表示一個文字方塊,距離頁面左邊界100px和頁面上邊界100px。 在Netscape Navigator 4系列中, 使用以下JavaScript移動上面的文字方塊。
document.layers['sample'].left = 200;
但是,在Internet Explorer 4中,則要使用不同的代碼。
document.all['sample'].style.left = 200;
為了移動文字方塊的功能可以在兩個瀏覽器中運行(即瀏覽器兼容性),須使用以下代碼(在沒有跨瀏覽器的標準操作方法時的做法)
if (document.all) document.all['sample'].style.left = 200; else if (document.layers) document.layers['sample'].left = 200;
更標準的語句(推薦使用): 以下代碼基於W3C標準DOM,能在Mozilla系列瀏覽器、Internet Explorer的新近版本和各種遵守標準標準的瀏覽器中。
document.getElementById('sample').style.left = '200px';
外部連結
- QuirksMode (頁面存檔備份,存於網際網路檔案館) — 市場上瀏覽器的差異及解決方法
- X (頁面存檔備份,存於網際網路檔案館) — 跨瀏覽器的JavaScript庫及應用實例
- Crosscheck — JavaScript單元測試框架,可以模擬各種瀏覽器和平台環境。
- browsershots.org (頁面存檔備份,存於網際網路檔案館) — 免費開源資源,可以讓網站在一同瀏覽器中顯示。
- Cross-Browser — 提供網站跨瀏覽器輸出的截圖功能。
- Multi-Browser Viewer (頁面存檔備份,存於網際網路檔案館) — 跨瀏覽器測試軟件,可以讓不同瀏覽器在同一電腦上執行。
- BrowserSeal (頁面存檔備份,存於網際網路檔案館) — 網站跨瀏覽器輸出的截圖軟入
- Google Cross Browser FAQ's (頁面存檔備份,存於網際網路檔案館) — Google Chrome的官方跨瀏覽器指引