十個實用但IE不支持的CSS屬性

来源:http://www.cnblogs.com/shouce/archive/2016/04/18/5403104.html
-Advertisement-
Play Games

對IE瀏覽器尤其是IE6的抱怨基本已進入麻痹狀態,偶爾甚至產生非常消極的想法:這個世界只有一個瀏覽器就好了,哪怕這唯一的瀏覽器就是IE6。當然,這樣的想法是非常病態的,馬上打消。本文裡面,介紹了10個很實但IE卻不支持的CSS屬性,列出這些屬性並不是為了數落IE(數落也沒用),而是你瞭解了哪些CSS ...


對IE瀏覽器尤其是IE6的抱怨基本已進入麻痹狀態,偶爾甚至產生非常消極的想法:這個世界只有一個瀏覽器就好了,哪怕這唯一的瀏覽器就是IE6。當然,這樣的想法是非常病態的,馬上打消。本文裡面,介紹了10個很實但IE卻不支持的CSS屬性,列出這些屬性並不是為了數落IE(數落也沒用),而是你瞭解了哪些CSS屬性是IE不支持的,就更有針對性的去編寫CSS和Hack了。

1. Outline

在調試CSS問題的時候,我常常在指定元素上添加border來精確的查看該元素會發生什麼並幫助確定問題的來源。這常常是有效的,因為它可以在布 局上給我更加具體的可視性。但是如果是塊級元素,這可能會發生某些錯誤——在任何塊級元素上添加1px的邊框很可能會影響到佈局,它會讓這個元素的寬度額 外增加2px。

outline 屬性是完美的替代者,因為它可以在不影響文檔流的情況下呈現該對象。但是IE6 和IE7 不支持 outline 屬性,所以,它不能在這兩個瀏覽器中用於調試。

2. Inherit (值)

在CSS開發中有很多這樣的例子:通過在特定元素上設置某些樣式來告訴該元素來“繼承”它父級元素的所有已添加的屬性,這樣你就可以避免相當多的鍵盤輸入。

這可以通過設置 inherit 來很容易的實現。這可能很有用。比如,當重寫 background 屬性的時候,常常會有很多的文字在該屬性中(色彩、圖片的URL地址、位置等)。所以,與其重新寫這些值,你可能僅僅想要考慮中的元素和其父級元素有相同 的背景屬性,一個 inherit 值就可以搞定一切——這顯然大大的節省了鍵盤輸入。

不幸的是, inherit 值在IE6和IE7不被支持(除了用於 direction (文字方向) 和 visibility 屬性)。

某人說,代碼就像女人的裙子——越短越好,看來IE會阻礙我們這個願望的實現。

3. Empty-Cells

該屬性只用於table或者”display”屬性被設置為”table-cell”的元素。如果你動態的為一個table添加內容,就可能會遇到某個單元格的內容為空的情況,然後你又不希望這個空的單元格的邊框、背景色、背景圖片等隱藏掉。

使用”empty-cells: hide”就能解決這個問題,它會將可能出現這種情況的單元格完全隱藏掉。

Internet Explorer 不支持empty-cells屬性。

4. Caption-Side

說到table 的屬性,這個屬性用於聲明顯示在表格的側欄的表格標題。它接受 top 、 bottom 、 left 和 right 四個值。Internet Exporer 不支持這個屬性,table的標題在IE6和IE7中將總是出現在表格的頂部。

5. Counter-Increment / Counter-Reset

有序列表(<ol>)非常方便,因為它可以省去你手工添加遞增數字的麻煩,而且它允許你不用更改數字就能改變列表的序列。

CSS 擁有 counter-increment 和 counter-reset 屬性,它允許你用來自動生成遞增數字到幾乎所有的html元素上,就像有序列表的效果一樣。

這裡有個示例:

1 2 h2 {counter-increment: headers;} h2:before {content: counter(headers) ". ";}

上面的樣式將在所有的 <h2> 標簽前面自動添加遞增的數字,而且允許你在h2標簽上實現和li標簽同樣的的效果。

但是IE6, IE7 甚至Safari(直到3.x版本)還不支持這些屬性。當然,IE6也不支持:before 偽元素。

6. Min-Height

有時,一個網站的設計或佈局結構需要一個有固定高度的內容區域,否則特定的視覺效果就會丟掉。這可能會因為一個漸變背景、一個獨特的下拉列表、 或者可能是因為PS出來的很酷的發光效果。但是有的時候,頁面中的內容會比較多,而頁面卻不能像預期那樣展開。

這個時候就需要用到 min-height 屬性了,因為它可以告訴瀏覽器在一個特定的塊級元素上渲染最小的高度,不管內容的實際高度是否達到了這個最小高度。然後呢,如果內容超出了最小高度,該元素就會適度的擴展開。

使用min-height 唯一需要註意到的是它在IE6中不被支持。我們都知道IE6在(緩慢的)退出歷史舞臺,但是有的客戶可能仍然要求他們的網站支持這個該死的瀏覽器。

不過令人高興的是,IE6 渲染 height 的值的方法正好和其它瀏覽器渲染“min-height”的方式一樣,所以你只需要一個針對IE6的hack或獨立的樣式表來為該元素添加特定的 height ,這個問題就解決了。

IE6 同樣無視 min-width 、 max-height 和 max-width , 但是上述方法在這些屬性上也是可行的。

7. :hover

從技術上來說,:hover只是一個偽類,但是它在IE6中不被支持(IE7和IE8支持)。:hover偽類允許你在元素上添加任何的滑鼠經過樣式。這非常有用,可以避免(至少在某種程度上)使用javascript。

但是如果你的網站,需要完全支持IE6,特別是在中國這種IE6一手遮天的情況下,那麼你就必須考慮取消使用這個偽類,除非相關的標簽有個”href”屬性,比如<a>標簽。而且如果要實現這種效果,可能必須藉助於javascript和額外的樣式。

8. Display

Display 通常被設置為這三個值中的一個: block、inline和 none。“得益於”IE,Display的其它值很少被用到。這些值包括 inline-block、table、inline-table和table-cell等,這些屬性對於解決一些特殊的佈局問題時,是很有用的。

所以,儘管IE 確實支持Display的這三個基本屬性,但是它基本上不支持其它屬性。

其實,IE8對display的屬性支持已經相當完整了。不過,對於inline-block屬性,IE6/7只支持本身為inline的元素。

9. Clip

這是一個在特殊情況下能派上用場的很有趣的CSS屬性。它可能和不可預知的、動態生成的內容結合起來。簡單來說,這個屬性允許你在一個特定的元素上 指定隱藏區域——也可以理解為,在一個絕對定位的元素中,按照一定的設置來裁剪該元素的顯示區域,超出該區域的內容會被隱藏掉。語法看起來像這樣的:

1 2 3 4 5 6 7 div.clipped {          padding: 20px;          width: 400px;          height: 400px;          clip: rect(20px, 300px, 200px, 100px);          position: absolute; }

修剪只能用於一個絕對定位的元素,而且只用使用矩形區域。括弧內的數字划出的區域(200px*180px大小)為可見區域,該區域以外的內容不可見或者被剪切掉。

技術上來講, clip 屬性被IE支持,但是只支持無逗號的語法,比如

1 2 3 4 5 6 7 div.clipped {     padding: 20px;     width: 400px;     height: 400px;     clip: rect(20px 300px 200px 100px);     position: absolute; }

上面的樣式(rect後面括弧里的屬性沒有用逗號隔開)在大多數瀏覽器下都可運行,但是可能不會通過CSS驗證,因為語句沒有用逗號隔開。

10. :focus

這是另外一個偽類需要在這裡被提及的,因為所有的非IE瀏覽器,都支持這個屬性。:focus偽類允許你聲明一個特別的樣式,當一個頁面元素成為鍵 盤(滑鼠)焦點的時候,將該樣式動態的應用到該元素上。這在表單元素上非常有用,因為你可以在一個輸入框被選中的時候給它添加一個邊框。

下麵的樣式將在輸入框成為鍵盤焦點的時候添加一個紅色的邊框:

1 2 3 input:focus {         border: 1px solid #f00; }
   
您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 3.4--數據類型 數據類型分為 boolean , string, object , function , number,undefinde 3.4.1--typeof 操作符 typeof 操作符在safari5,chrome7以及之前版本 會將正則表達式 返回為"function",而在其他瀏 ...
  • 前段時間用到jquery上傳插件uploadify時,始終出現系統報出 http error 302 的錯誤。 網上大量搜集信息,基本上都是說session值丟失的問題,根據網友提供的解決方案進行修改,問題並沒有解決。 因此,不排除這是解決302錯誤的解決方法之一,但是我接下來提出另一解決方案,考慮 ...
  • 摘要: artEditor.js是一款移動端的富文本編輯器,支持圖片上傳,後面會增加表情、小視頻等功能。最近有朋友反饋artEditor是否支持表單提交,當然是支持的,在未開發該功能之前,你可以像下麵這樣來實現表單提交 新功能: 新增formInputId參數,該參數表示form隱藏域的id,會將編 ...
  • 在這個展示,我們提供最好的網頁設計師10圖標生成器。這些圖標生成器是免費使用的,有些是與高級功能,將幫助你產生引人註目的和有吸引力的網頁為您的網站。 為了包起來,他們都可以自由下載,所以在。來,看看,選擇你的選擇。我們希望這個列表證明你是最好的。請隨時與你的朋友分享這份名單,也讓我們知道你對這本編輯 ...
  • 摘要: aTpl.js是一款模板插件,該插件支持ie5+,chrome等瀏覽器以及移動端瀏覽器,支持for和if語法,以及表達式。最近對aTpl.js模板插件增加了新的功能,支持字元串模板,同時增加了模板緩存功能。 項目地址:https://github.com/baixuexiyang/aTpl ...
  • 1、sessionStorage 2、localStorage 3、Database Storage 4、globalStorage 5、相容性 參考文獻 本地持久化存儲一直是本地客戶端程式優於 web 程式的一個方面。對於本地應用程式,操作系統會一共一個抽象層,用於存儲和獲取特定於應用程式的數據, ...
  • 1. jQuery入門 1.1. 優點 解決瀏覽器的相容性問題。 支持擴展,通過插件方式實現擴展,避免特性蠕變。 使用隱式迭代的技術,使方法的操作面向集合。如“.hide()” 使用方法鏈接編程方式,使多重操作集於一行。 強大的選擇符。 可靠的事件處理機制。 完善的Ajax。 行為層與結構層的分離。 ...
  • 字元x 字元 x\\ 反斜線字元\0n 帶有八進位值 0 的字元 n (0 <= n <= 7)\0nn 帶有八進位值 0 的字元 nn (0 <= n <= 7)\0mnn 帶有八進位值 0 的字元 mnn(0 <= m <= 3、0 <= n <= 7)\xhh 帶有十六進位值 0x 的字元 h ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...