自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

手把手教你打造一個純CSS圖標庫

開發(fā) 前端
使用CSS繪制線條,用到的不外乎兩個屬性:border & box-shadow。而形狀則可以用border-radius、transform控制變形,位置則會用到絕對定位、transform、margin等屬性來調(diào)整。CSS的繪圖,做過幾個就知道大概是怎么回事了,歸根到底,還是幾何。

來,干了這碗安利

寫這篇文章的目的其實就是為了安利一下我的圖標庫:iconoo,所以,開門見山,star吧少年少婦們!(這樣的我是不是應該要加個github互粉的團伙了?)

主題說完了,下面進入正題。

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

  1. 直接使用圖片;
  2. 使用css/svg直接在瀏覽器中繪制圖標。

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

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

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

手抓手教學時間

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

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

  1. .plus { 
  2.     box-sizing : border-box; 
  3.     display    : inline-block; 
  4.     position   : relative
  5.     font-size  : 20px; 
  6.  
  7. .plus:before, .plus:after { 
  8.     content        : ''
  9.     pointer-events : none; 
  10.     position       : absolute
  11.     left           : 50%; 
  12.     top            : 50%; 
  13.     transform      : translate(-50%, -50%); 
  14.     box-shadow     : inset 0 0 0 1em; 
  15.  
  16. .plus:before { 
  17.     width  : 1em; 
  18.     height : 2px; 
  19.  
  20. .plus:after { 
  21.     height : 1em; 
  22.     width  : 2px; 
  23.  

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

進階玩法

首先來看看這個圖片圖標:

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

 

  1. .icon-img { 
  2.     display: inline-block; 
  3.     position: relative
  4.     box-sizing: border-box; 
  5.     width: 90px; 
  6.     height: 80px; 
  7.     border: 5px solid; 
  8.     border-radius: 10px; 
  9.     color: #2ba5bb; 
  10.     overflow: hidden; 
  11.  
  12. .icon-img:before,.icon-img:after { 
  13.     content: ''
  14.     pointer-events: none; 
  15.     position: absolute
  16.  
  17. .icon-img:before { 
  18.     width: 10px; 
  19.     height: 10px; 
  20.     top: 18px; 
  21.     right: 20px; 
  22.     box-shadow: inset 0 0 0 1em; 
  23.     border-radius: 50%; 
  24.  
  25. .icon-img:after { 
  26.     width: 60px; 
  27.     height: 50px; 
  28.     left: 0; 
  29.     bottom: -27px; 
  30.     box-shadow: inset 0 0 0 50px,30px -20px 0 0; 
  31.     transform: rotate(45deg); 
  32.  

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

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

再來看一個帶變形的:

 

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

 

 

  1. .icon-codepen { 
  2.     display: inline-block; 
  3.     position: relative
  4.     box-sizing: border-box; 
  5.     color: #2ba5bb; 
  6.     width: 2px; 
  7.     height: 10px; 
  8.     box-shadow: inset 0 0 0 32px,0 15px,-11px 7px,11px 7px; 
  9.  
  10. .icon-codepen:before, 
  11. .icon-codepen:after { 
  12.     content: ''
  13.     pointer-events: none; 
  14.     position: absolute
  15.     width: 11px; 
  16.     height: 4px; 
  17.  
  18. .icon-codepen:before { 
  19.     right: 2px; 
  20.     top: 3px; 
  21.     transform: skew(0,-35deg) scaleY(0.6); 
  22.     box-shadow: inset 0 0 0 32px,0 13px,11px 26px,12px 39px; 
  23.  
  24. .icon-codepen:after { 
  25.     left: 2px; 
  26.     top: 3px; 
  27.     transform: skew(0,35deg) scaleY(0.6); 
  28.     box-shadow: inset 0 0 0 32px,0 13px,-11px 26px,-12px 39px; 
  29.  

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

叔叔,我想裝逼

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

[[174955]] 

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

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

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

[[174956]] 

http://codepen.io/fbrz/pen/iqtlk點擊預覽 ,不多說,拿去不謝!

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

首尾呼應

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

責任編輯:龐桂玉 來源: segmentfault
相關(guān)推薦

2021-06-22 10:43:03

Webpack loader plugin

2024-11-05 16:40:24

JavaScript搜索引擎

2022-02-25 09:41:05

python搜索引擎

2021-08-24 10:02:21

JavaScript網(wǎng)頁搜索 前端

2022-06-28 15:29:56

Python編程語言計時器

2019-08-26 09:25:23

RedisJavaLinux

2022-02-17 10:26:17

JavaScript掃雷游戲前端

2022-08-26 08:01:38

DashWebJavaScrip

2022-09-22 12:38:46

antd form組件代碼

2021-07-14 09:00:00

JavaFX開發(fā)應用

2011-01-10 14:41:26

2011-05-03 15:59:00

黑盒打印機

2020-11-27 07:38:43

MongoDB

2021-11-01 10:26:07

CanvasAPI畫布技術(shù)HTML5

2020-05-09 09:59:52

Python數(shù)據(jù)土星

2023-03-22 09:00:38

2018-11-22 09:17:21

消息推送系統(tǒng)

2019-10-29 15:46:07

區(qū)塊鏈區(qū)塊鏈技術(shù)

2021-12-30 08:56:57

Python摸魚倒計界面Python基礎(chǔ)

2021-06-10 07:49:28

Python詞云圖wordcloud
點贊
收藏

51CTO技術(shù)棧公眾號