使用css實現(xiàn)全兼容瀏覽器的三角形
在當前流行的的網(wǎng)站上,我們經(jīng)常會看到一些小三角形的下拉提示(微博頂部的下拉菜單),簡單的方式可以使用一張圖片代替,但是隨著前端技術(shù)的發(fā)展,以及開發(fā)者對于前端性能的“吹毛求疵”,越來越多的前端開發(fā)者開始“返璞歸真”,在能不使用圖片的場景中減少圖片使用,css圖標相對于圖片還有個優(yōu)勢是我們可以方便的定制圖標的大小以及顏色。
css實現(xiàn)三角形圖標已不是什么新鮮技術(shù),之前也有很多相關(guān)的技術(shù)文章,這篇文章主要是分析下在實際場景中使用時遇到的問題以及如何回避這些問題。
基本原理大同小異,這里主要介紹利用css border(當然還可以使用css3的旋轉(zhuǎn)技術(shù)實現(xiàn),由于兼容性問題這里不涉及了)。
css border實現(xiàn)
一個div或者元素的border
并不是我們直觀意義上的一條有高度的線,而是一個等高梯形或者三角形(寬高為0時),可以看一下效果:
div定義:
<div class="arrow1"></div>
css:
.arrow1{ width: 0px; height:0px; border-width: 30px; border-style: solid; border-color: #007998 #47A447 #3C6AB9 #D2322D; }
最終效果:
可以看到每一個方向的border都是一個三角形,那么我們只需把對應(yīng)方向剩余其他方向的border設(shè)置為透明或者隱藏掉就可以得到任何方向的一個三角形了。如果我們想得到一個下拉圖標,我們可以將border的左右和下邊框改為透明,css改動如下:
.arrow1{ width: 0px; height:0px; border-width: 30px; border-style: solid; border-color: #007998 transparent transparent transparent; }
再看一下效果:
注:transparent 屬性用來在 background 中將 background-color 選項設(shè)置為背景顏色透明
bingo!就是我們想要的效果,但是在ie6下杯具鳥!
長長的大黑框,讓人無法直視,這是因為ie6不支持transparent
透明屬性,這時候我們可以將對應(yīng)區(qū)域的border的樣式設(shè)置為dashed
,dashed
在邊框?qū)挾群艽髸r,會隱藏掉。css修改如下:
.arrow1{ width: 0px; height:0px; border-width: 30px; border-style: solid; border-color: #007998 transparent transparent transparent; }
效果如下(ie6下查看):
但是,到此仍沒有結(jié)束,我們設(shè)置個陰影來查看下最終生成的效果:
即便是我們看到的已經(jīng)生成一個我們需要的三角形,但是三角形的占用高度仍是原高度,這會導(dǎo)致在和其他元素使用時,造成上移的效果。此時,我們需要把下邊框的高度設(shè)置為0:
.arrow1{ width: 0px; height:0px; border-width: 30px 30px 0; border-style: solid; border-color: #007998 transparent transparent transparent; }
再來看看效果:
似乎仍是不太友好,在使用時我們?nèi)孕枰薷膶?yīng)的顏色,能不能根據(jù)父元素設(shè)定的顏色,顯示對應(yīng)的顏色呢?我們需要把border-color
修改下:
.arrow1{ width: 0px; height:0px; line-height: 0px; border-width: 30px 30px 0; border-style: solid dashed dashed dashed; border-left-color: transparent; border-right-color: transparent; }
效果(使用當前字體顏色):
當然除了利用css border生成外,我們還可以使用特殊字符◇疊加定位來生成,也可以使用css3的旋轉(zhuǎn)來生成(ie6下需要hack處理)。利用border是一種常用而且簡單兼容的方式
您可能感興趣的文章
- 01-11純CSS實現(xiàn)鼠標放上去改變文字內(nèi)容
- 01-11CSS可以做的幾個令你嘆為觀止的實例分享
- 01-11CSS3中Transition屬性詳解以及示例分享
- 01-11詳細分析css float 屬性以及position:absolute 的區(qū)別
- 01-11告別AJAX實現(xiàn)無刷新提交表單
- 01-11使用css實現(xiàn)全兼容tooltip提示框
- 01-11從零學(xué)CSS系列之文本屬性
- 01-11HTML實現(xiàn)title 屬性換行小技巧
- 01-11用css截取字符的幾種方法詳解(css排版隱藏溢出文本)
- 01-11CSS3+Js實現(xiàn)響應(yīng)式導(dǎo)航條


閱讀排行
本欄相關(guān)
- 04-02html5算法,html5協(xié)議
- 04-02html5圖形,html5圖形縮放
- 04-02html5登錄模板,html5登錄注冊模板
- 04-02html5的例子,HTML示例
- 04-02html5的canvas,html5的canvas的作用
- 04-02關(guān)于html5 視頻代碼的信息
- 04-02html5chm手冊,html操作手冊
- 04-02朋友圈html5,朋友圈發(fā)泄情緒的句子
- 04-02html5的新特性有哪些,HTML5的新特性有哪
- 04-02html5掃二維碼,html5調(diào)用手機攝像頭掃描
隨機閱讀
- 01-10C#中split用法實例總結(jié)
- 08-05dedecms(織夢)副欄目數(shù)量限制代碼修改
- 08-05織夢dedecms什么時候用欄目交叉功能?
- 01-10使用C語言求解撲克牌的順子及n個骰子
- 01-11ajax實現(xiàn)頁面的局部加載
- 01-10delphi制作wav文件的方法
- 04-02jquery與jsp,用jquery
- 01-11Mac OSX 打開原生自帶讀寫NTFS功能(圖文
- 08-05DEDE織夢data目錄下的sessions文件夾有什
- 01-10SublimeText編譯C開發(fā)環(huán)境設(shè)置