亚洲精品久久久中文字幕-亚洲精品久久片久久-亚洲精品久久青草-亚洲精品久久婷婷爱久久婷婷-亚洲精品久久午夜香蕉

您的位置:首頁技術(shù)文章
文章詳情頁

使用css實現(xiàn)全兼容瀏覽器的三角形

瀏覽:4日期:2022-06-02 11:51:59

在當前流行的的網(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></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è)置為dasheddashed在邊框?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是一種常用而且簡單兼容的方式

標簽: CSS HTML
相關(guān)文章:
主站蜘蛛池模板: 国产三级观看 | 精品国产免费第一区二区三区日韩 | 亚洲人成网站观看在线播放 | 欧美一区二区视频在线观看 | 午夜精品久久久久久久第一页 | 亚洲一区二区三区福利在线 | 亚洲精品色一区二区三区 | 日韩国产一区二区 | 特级理论片 | 久久久久久久综合 | 欧美人一级淫片a免费播放 欧美人七十二式性视频教程一 | 精品国产综合成人亚洲区 | 特黄的欧美毛片 | 国内精品一区二区在线观看 | 亚洲精品久久久久中文字小说 | 综合伊人久久在一二三区 | 国产伦精品一区二区三区视频金莲 | 国产一区亚洲 | 国产婷婷一区二区在线观看 | 2022麻豆福利午夜久久 | 国产精品天天看 | 国产精品午夜激爽毛片 | 秀人网艾小青国产精品视频 | 国产一久久香蕉国产线看观看 | 成人午夜小视频手机在线看 | 国外免费精品视频在线观看 | 久久久久久国产精品免费 | 国产sss | 国产一区2区3区 | 久久精品亚洲一区二区 | 国产区综合另类亚洲欧美 | 久久青草91线频免费观看 | 亚洲第一区视频在线观看 | 综合图片区 | yiren22开心综合成人网 | 亚洲精品第五页中文字幕 | 国产福利小视频在线播放观看 | 成人影院午夜久久影院 | 国产精品v欧美精品∨日韩 国产精品www | 中文精品久久久久国产网址 | 尤物视频免费观看 |