国产99久久精品_欧美日本韩国一区二区_激情小说综合网_欧美一级二级视频_午夜av电影_日本久久精品视频

最新文章專題視頻專題問答1問答10問答100問答1000問答2000關(guān)鍵字專題1關(guān)鍵字專題50關(guān)鍵字專題500關(guān)鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關(guān)鍵字專題關(guān)鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
問答文章1 問答文章501 問答文章1001 問答文章1501 問答文章2001 問答文章2501 問答文章3001 問答文章3501 問答文章4001 問答文章4501 問答文章5001 問答文章5501 問答文章6001 問答文章6501 問答文章7001 問答文章7501 問答文章8001 問答文章8501 問答文章9001 問答文章9501
當(dāng)前位置: 首頁 - 科技 - 知識百科 - 正文

手把手教你打造一個純CSS圖標(biāo)庫

來源:懂視網(wǎng) 責(zé)編:小采 時間:2020-11-27 18:54:02
文檔

手把手教你打造一個純CSS圖標(biāo)庫

手把手教你打造一個純CSS圖標(biāo)庫:寫這篇文章的目的其實就是為了安利一下我的圖標(biāo)庫:iconoo,所以,開門見山,star吧少年少婦們!(這樣的我是不是應(yīng)該要加個github互粉的團(tuán)伙了)主題說完了,下面進(jìn)入正題。在web開發(fā)中,我們經(jīng)常要用到一些小圖標(biāo)(加減勾叉等)。通常做法就兩種:直接使用圖片
推薦度:
導(dǎo)讀手把手教你打造一個純CSS圖標(biāo)庫:寫這篇文章的目的其實就是為了安利一下我的圖標(biāo)庫:iconoo,所以,開門見山,star吧少年少婦們!(這樣的我是不是應(yīng)該要加個github互粉的團(tuán)伙了)主題說完了,下面進(jìn)入正題。在web開發(fā)中,我們經(jīng)常要用到一些小圖標(biāo)(加減勾叉等)。通常做法就兩種:直接使用圖片
寫這篇文章的目的其實就是為了安利一下我的圖標(biāo)庫:iconoo,所以,開門見山,star吧少年少婦們!(這樣的我是不是應(yīng)該要加個github互粉的團(tuán)伙了?)

1.png

主題說完了,下面進(jìn)入正題。

在web開發(fā)中,我們經(jīng)常要用到一些小圖標(biāo)(加減勾叉等)。通常做法就兩種:

直接使用圖片;

使用css/svg直接在瀏覽器中繪制圖標(biāo)。

方案1:由于圖標(biāo)圖片比較多,而且體積很小,為了減少請求所以很多時候我們會用雪碧圖這種技術(shù)來將圖標(biāo)拼湊在同一張圖片里面。你也能想到,一堆圖標(biāo)的雪碧圖,修改維護(hù)會相當(dāng)麻煩!現(xiàn)在比較好的方案是使用webpack引入圖片,小圖直接轉(zhuǎn)換成base64插入css中。直接使用圖片比較簡單,這也是目前比較主流的做法。

方案2: 相比方案1,明顯可以減小資源的體積,只需要幾條css/svg命令就可以繪制出精美的圖標(biāo),而且不受圖片尺寸限制,可大可小非常靈活。初看方案2的一堆代碼可能會覺得非常難,但其實很多簡單的圖標(biāo)都是非常容易實現(xiàn)的。

接下來就是妹子們最期待的茄果叔叔手把手教學(xué)時間啦。

手抓手教學(xué)時間

使用CSS繪制線條,用到的不外乎兩個屬性:border & box-shadow。而形狀則可以用border-radius、transform控制變形,位置則會用到絕對定位、transform、margin等屬性來調(diào)整。CSS的繪圖,做過幾個就知道大概是怎么回事了,歸根到底,還是幾何。如果覺得幾何燒腦,那就直接用 iconoo 吧~~~

基本原理說了,下面來擼一發(fā),先看看最簡單的加號:

.plus { 
 box-sizing : border-box; 
 display : inline-block; 
 position : relative; 
 font-size : 20px; 
} 
 
.plus:before, .plus:after { 
 content : ''; 
 pointer-events : none; 
 position : absolute; 
 left : 50%; 
 top : 50%; 
 transform : translate(-50%, -50%); 
 box-shadow : inset 0 0 0 1em; 
} 
 
.plus:before { 
 width : 1em; 
 height : 2px; 
} 
 
.plus:after { 
 height : 1em; 
 width : 2px; 
}

代碼還是非常簡單的,首先我們這里用到了before和after兩個偽類增加可用的標(biāo)簽,不然只有一個標(biāo)簽,要玩出花來實在是太難。content顧名思義就是內(nèi)容,里面可以加各種字符,甚至是換行之類的控制符。而pointer-events:none則是消除了鼠標(biāo)指針事件,這樣元素就具有穿透性了,具體細(xì)節(jié)還請自行搜索哈,這里就不多說了。繪圖的核心,就是通過設(shè)置兩個偽類的寬高和陰影來繪制橫豎兩條線,位置方面是通過絕對定位+反向偏移的方式,巧妙利用了這兩個屬性百分比參照的不同實現(xiàn)了橫豎的居中。所有尺寸除了線寬(2px)外都使用em這個相對單位,所以調(diào)整font-size的值就可以調(diào)整圖標(biāo)的大小了。要調(diào)整線寬呢,就將所有px單位的尺寸都一并改了即可。

進(jìn)階玩法

首先來看看這個圖片圖標(biāo):

1.png

這個圖形網(wǎng)上說的應(yīng)該還是比較多的了,然而我第一眼看到的時候還是懵逼了。。分析一下,最外層的邊框明顯可以用border來做,然后用個before來做圓點(diǎn)也非常簡單,關(guān)鍵是兩座大山要如何繪制呢?box-shadow貌似可以做多層邊框呢,然后加個旋轉(zhuǎn)是不是就出來了呢?最后隱藏邊框之外的部分就可以了。繪制流程如下:

1.png

.icon-img { 
 display: inline-block; 
 position: relative; 
 box-sizing: border-box; 
 width: 90px; 
 height: 80px; 
 border: 5px solid; 
 border-radius: 10px; 
 color: #2ba5bb; 
 overflow: hidden; 
} 
 
.icon-img:before,.icon-img:after { 
 content: ''; 
 pointer-events: none; 
 position: absolute; 
} 
 
.icon-img:before { 
 width: 10px; 
 height: 10px; 
 top: 18px; 
 right: 20px; 
 box-shadow: inset 0 0 0 1em; 
 border-radius: 50%; 
} 
 
.icon-img:after { 
 width: 60px; 
 height: 50px; 
 left: 0; 
 bottom: -27px; 
 box-shadow: inset 0 0 0 50px,30px -20px 0 0; 
 transform: rotate(45deg); 
}

代碼是臨時拼的,就沒做成em單位了。呃,為什么要做成em單位呢?

我們在使用圖標(biāo)的時候,可能尺寸每次都不一樣,但圖標(biāo)的尺寸都是有關(guān)聯(lián)的,調(diào)整起來相當(dāng)費(fèi)勁。當(dāng)然你可以會想到用zoom、scale來做縮放,但是這樣的縮放線寬也會隨之變化了。設(shè)置em的話,在icon級設(shè)置font-size,然后icon本身以及后代都以這個font-size為參照,只調(diào)整font-size就完成了圖標(biāo)的等比縮放了。

再來看一個帶變形的:

1.png

這個一看其實就能猜到是怎么畫的,幾何關(guān)系貌似也比較簡單,但是要映射到css的規(guī)則里面卻非常復(fù)雜。先看看流程:

1.png

.icon-codepen { 
 display: inline-block; 
 position: relative; 
 box-sizing: border-box; 
 color: #2ba5bb; 
 width: 2px; 
 height: 10px; 
 box-shadow: inset 0 0 0 32px,0 15px,-11px 7px,11px 7px; 
} 
 
.icon-codepen:before, 
.icon-codepen:after { 
 content: ''; 
 pointer-events: none; 
 position: absolute; 
 width: 11px; 
 height: 4px; 
} 
 
.icon-codepen:before { 
 right: 2px; 
 top: 3px; 
 transform: skew(0,-35deg) scaleY(0.6); 
 box-shadow: inset 0 0 0 32px,0 13px,11px 26px,12px 39px; 
} 
 
.icon-codepen:after { 
 left: 2px; 
 top: 3px; 
 transform: skew(0,35deg) scaleY(0.6); 
 box-shadow: inset 0 0 0 32px,0 13px,-11px 26px,-12px 39px; 
}

難點(diǎn)就在長寬的變形上,對于變形比較簡單的方法是使用變換矩陣來求解。圖形學(xué)學(xué)的不好的話,那就比較痛苦了,如果不追求單標(biāo)簽的話,可以將每條邊用一個標(biāo)簽表示,這樣就很好處理了。

叔叔,我想裝逼

怎么樣?覺得上面這些都是小玩意?想裝逼了?好,叔叔教你!

1.png

蒙娜麗莎?什么鬼?我會告訴你這也可以用一個單標(biāo)簽純CSS畫出來的嗎?

http://codepen.io/jaysalvat/p...點(diǎn)擊預(yù)覽 ,自己看去,幾千條box-shadow構(gòu)成的蒙娜麗莎,看的我內(nèi)分泌都失調(diào)了。。

靜態(tài)的還不夠,那來點(diǎn)動態(tài)的:

1011161-20161017191451638-802967520.gif

http://codepen.io/fbrz/pen/iqtlk點(diǎn)擊預(yù)覽 ,不多說,拿去不謝!

更多CSS玩意兒,請到codepen上去探寶吧!如果codepen都打不開,可以到我博客園去下載相應(yīng)的css文件吧!什么,沒有提供下載鏈接?F12大法搞起!

首尾呼應(yīng)

語文老師說了,文章要首尾呼應(yīng)升華主題,so one more time:寫這篇文章的目的其實就是為了安利一下我的圖標(biāo)庫:iconoo,所以,開門見山,star吧少年少婦們!

聲明:本網(wǎng)頁內(nèi)容旨在傳播知識,若有侵權(quán)等問題請及時與本網(wǎng)聯(lián)系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

文檔

手把手教你打造一個純CSS圖標(biāo)庫

手把手教你打造一個純CSS圖標(biāo)庫:寫這篇文章的目的其實就是為了安利一下我的圖標(biāo)庫:iconoo,所以,開門見山,star吧少年少婦們!(這樣的我是不是應(yīng)該要加個github互粉的團(tuán)伙了)主題說完了,下面進(jìn)入正題。在web開發(fā)中,我們經(jīng)常要用到一些小圖標(biāo)(加減勾叉等)。通常做法就兩種:直接使用圖片
推薦度:
標(biāo)簽: icon 手把手教你 css
  • 熱門焦點(diǎn)

最新推薦

猜你喜歡

熱門推薦

專題
Top
主站蜘蛛池模板: 最新国产精品亚洲 | 欧美亚洲国产精品第一页 | 国产99久久亚洲综合精品 | 中文字幕第一页亚洲 | 欧美日韩国产色 | 欧美日韩国产高清 | 国产精品亚洲一区二区三区在线播放 | 欧美射| 国产成人亚洲欧美三区综合 | 欧美日韩精品免费一区二区三区 | 亚洲精品在线免费看 | 99久久精品费精品国产一区二区 | 精品国产日韩亚洲一区91 | 国产成人精品一区二区免费视频 | 国产在线一区二区三区欧美 | 欧美第一精品 | 国产精品一区二区手机在线观看 | 国产在线成人一区二区 | 欧美亚洲自拍偷拍 | 美国人禽交ooo | 亚洲国产精品一区二区久久 | a色毛片免费视频 | 日本一区二区三区免费高清在线 | 国内在线观看精品免费视频 | 国产超级乱淫片中文 | 亚洲 欧美 手机 在线观看 | 国产毛片一区二区三区精品 | 日韩国产电影 | 国产成人精品日本亚洲11 | 国产情侣91 | 91成人爽a毛片一区二区 | 国产精品高清一区二区 | 欧美精品v日韩精品v国产精品 | 亚洲欧美影院 | 亚洲精品不卡久久久久久 | 日韩欧美在线不卡 | 美女视频一区二区 | 综合欧美亚洲 | 国产日韩中文字幕 | 日本一区二区三区视频在线观看 | 国产日韩亚洲 |