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

2020-12-25 TechWeb

推廣 | 令人窒息的獎品等你―2016最權威的全球開發者調研

來,幹了這碗安利

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

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

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

直接使用圖片; 使用css/svg直接在瀏覽器中繪製圖標。

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

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

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

手抓手教學時間

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

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

.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兩個偽類增加可用的標籤,不然只有一個標籤,要玩出花來實在是太難。content顧名思義就是內容,裡面可以加各種字符,甚至是換行之類的控制符。而pointer-events:none則是消除了滑鼠指針事件,這樣元素就具有穿透性了,具體細節還請自行搜索哈,這裡就不多說了。繪圖的核心,就是通過設置兩個偽類的寬高和陰影來繪製橫豎兩條線,位置方面是通過絕對定位+反向偏移的方式,巧妙利用了這兩個屬性百分比參照的不同實現了橫豎的居中。所有尺寸除了線寬(2px)外都使用em這個相對單位,所以調整font-size的值就可以調整圖標的大小了。要調整線寬呢,就將所有px單位的尺寸都一併改了即可。

進階玩法

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

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

.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單位呢?

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

再來看一個帶變形的:

這個一看其實就能猜到是怎麼畫的,幾何關係貌似也比較簡單,但是要映射到css的規則裡面卻非常複雜。先看看流程:

.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; }  

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

叔叔,我想裝逼

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

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

http://codepen.io/jaysalvat/p...點擊預覽 ,自己看去,幾千條box-shadow構成的蒙娜麗莎,看的我內分泌都失調了。。。

靜態的還不夠,那來點動態的:

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

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

首尾呼應

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

點讚 0

相關焦點

  • 剪映素材庫在哪裡 手把手教你剪映素材庫怎麼用
    剪映素材庫在哪裡 手把手教你剪映素材庫怎麼用時間:2020-07-01 17:09   來源:騰牛網    責任編輯:沫朵 川北在線核心提示:原標題:剪映素材庫在哪裡 手把手教你剪映素材庫怎麼用 剪映是非常好用的剪輯工具,現在很多人都愛用,裡面有很多功能,可以製作出很好的視頻。
  • 一個在線css三角形生成器
    接下來介紹的一款工具——css三角形生成器也是因為之前想要解放設計師的生產力, 自己又懶得切圖或者寫css代碼, 所以想來想去還是自己做一個能自動生成css三角形代碼的工具吧.>有了原型圖, 我們可以得到如下的任務細分圖:這裡筆者要提的一點是其實以上流程對於任何項目都適用, 包括你遇到的難解的問題, 都可以一步步把思路先理清楚, 把大目標拆解為一塊塊的小目標, 然後逐個擊破, 這樣大難題也就解決了.
  • 如何用純css打造類materialUI的按鈕點擊動畫並封裝成react組件
    但隨著對用戶體驗的越來越重視,對交互體驗要求的提高以及css3等新標準的出現,使得web更加大放異彩, 各種動效的實現都變得非常容易.筆者在研究materialUI框架時對於它的交互及其讚嘆.所以為了自己能實現一個類似materialUI的按鈕點擊動畫,並封裝到自己的UI庫中,筆者特地總結了一些思路,希望可以和廣大的前端工程師們一起探討.
  • 10個實用的CSS和JavaScript動畫插件/框架/庫
    10個實用的CSS和JavaScript動畫插件/框架/庫 站長之家(CHINAZ.com)12月1日編譯:在網站中嵌入動畫已經成為今年的設計趨勢之一
  • 百度地圖怎麼關閉足跡 手把手教你關閉百度地圖足跡
    百度地圖怎麼關閉足跡 手把手教你關閉百度地圖足跡時間:2018-03-18 11:40   來源:綠茶軟體園   責任編輯:沫朵 川北在線核心提示:原標題:百度地圖怎麼關閉足跡 手把手教你關閉百度地圖足跡 1. 首先打開百度地圖軟體,點擊軟體窗口左上角的頭像圖標,打開設置; 2.
  • 純css瀑布流樣式探索
    class="parent"> <div class="child"></div> <div class="child"></div> <div class="child"></div></div>效果圖如下:        發現有點問題,純CSS
  • 手把手教你和風物語怎麼加好友
    手把手教你和風物語怎麼加好友 來源:www.18183.com作者:熊熊小壯丁時間:2013-05-13 手把手教你和風物語怎麼加好友
  • 蝦米音樂怎麼連結電視 手把手教你蝦米音樂怎麼投屏
    蝦米音樂怎麼連結電視 手把手教你蝦米音樂怎麼投屏時間:2020-07-11 14:52   來源:騰牛網   責任編輯:沫朵 川北在線核心提示:原標題:蝦米音樂怎麼連結電視 手把手教你蝦米音樂怎麼投屏 蝦米音樂是一直以來都很受歡迎的音樂播放器,不少人聽歌都用這款軟體。
  • 超級簡單,輕鬆上傳圖標到iSlide圖表庫
    比較常用圖片庫的上傳功能圖標庫卻很少使用儘管圖標庫已經提供了16w+的圖標供用戶免費使用但是上傳功能又將數量增加到接近無限其實上傳圖標很簡單打開 iSlide 圖標庫點擊【上傳圖標】即可但是到了這一步大家可能會有一些疑問Q:什麼叫僅支持自定義形狀的上傳A:僅支持自定義形狀上傳:通過PPT自帶矢量形狀,自定義圖標上傳圖標庫。
  • 朋友手機發送的位置,怎麼分享到車載大屏導航,老司機手把手教你
    朋友手機發送的位置,怎麼分享到車載大屏導航,老司機手把手教你視頻地址:評論:0朋友手機發送的位置,怎麼分享到車載大屏導航,老司機手把手教你1/ 6朋友手機發送的位置,怎麼分享到車載大屏導航,老司機手把手教你猜你喜歡朋友手機發送的位置,怎麼分享到車載大屏導航,老司機手把手教你
  • 手把手教你製作excel會動的圖表
    手把手教你製作excel會動的圖表時間:2018-04-15 12:41   來源:系統天堂   責任編輯:沫朵 川北在線核心提示:原標題:excel會動的圖表怎麼製作? 手把手教你製作excel會動的圖表 excel會動的圖表怎麼製作?數據較多的時候,如何能夠在有限的屏幕寬度內瀏覽更多的數據呢?你是否想過讓數據動起來呢!
  • 手把手教你創建一個時尚的3D文字效果
    手把手教你創建一個時尚的3D文字效果 Photoshop的矢量工具是一個很強大的工具,只要你有心,就能製作出驚人的3 D效果字體。不過在矢量圖的使用上難度相對比較大。今天就跟大家分享一下如何用 Photoshop的矢量工具製作3 D字體。
  • 我的世界聖誕雪人圖文教程 手把手教你打造屬於自己的聖誕雪人
    我的世界聖誕雪人圖文教程 手把手教你打造屬於自己的聖誕雪人時間:2019-12-18 16:22   來源:小皮手遊網   責任編輯:沫朵 川北在線核心提示:原標題:我的世界聖誕雪人圖文教程 手把手教你打造屬於自己的聖誕雪人 聖誕節還有7天就到了,那麼為了迎接聖誕節的到來,想在你的庭院中建造一個可愛的小雪人該怎麼做呢
  • iconmonstr - 提供超過4000個精緻圖標免費商用的圖標庫網站
    一個超多簡約線條風格的免費圖標素材網站,非常值得收藏。介紹今天推薦的 iconmonstr 是一個以簡單線條為主的的免費圖標庫,截止發稿,收錄了超過4496個圖標!相比於很多簡約簡單的圖標,iconmonstr 的圖標表現力非常豐富,非常適合用在PPT、企業官網設計下的大圖標塊以及 UI 界面上的大圖標模塊,非常地好看。
  • 一個高性能js動畫庫velocity.js簡介
    這就是velocity.js動畫庫了。二、velocity的優點1、Velocity 是一個簡單易用、高性能、功能豐富的輕量級JS動畫庫。換句話說,如果你熟悉jquery的animate()函數,那麼你只需把animate()語法套用在velocity()就行。
  • Vue中使用animate.css實現動畫效果
    在實際開發過程中,有些頁面需要一些炫酷的動畫效果這時我們可以通過animate來實現Animate是一個非常實用的動畫庫官網: https://animate.style/Animate動畫庫裡面有很多實用的動畫效果展示如下:應用實例效果展示:使用方法:在vue中使用animate.css第一步:安裝
  • 我的世界溫馨別墅圖文教程 手把手教你打造屬於自己的溫馨別墅
    我的世界溫馨別墅圖文教程 手把手教你打造屬於自己的溫馨別墅時間:2019-12-24 14:54   來源:小皮手遊網   責任編輯:沫朵 川北在線核心提示:原標題:我的世界溫馨別墅圖文教程 手把手教你打造屬於自己的溫馨別墅 想要在遊戲內建造一個溫馨的別墅需要哪些步驟呢?
  • 抖音怎麼自己創作原聲 手把手教你製作製作原聲
    抖音怎麼自己創作原聲 手把手教你製作製作原聲時間:2018-09-26 15:31   來源:今日頭條   責任編輯:沫朵 川北在線核心提示:原標題:抖音怎麼自己創作原聲 手把手教你製作製作原聲 抖音軟體錄製視頻可以選擇軟體裡自帶的音樂,或者是你自己收藏的音樂,一般都是這樣做的,但是如何創作自己的原聲音樂呢?
  • 《我的世界手遊》沙漠堡壘建築建造教程 手把手教你打造逼格沙漠城堡
    《我的世界手遊》沙漠堡壘建築建造教程 手把手教你打造逼格沙漠城堡時間:2020-05-27 17:01   來源:遊俠網   責任編輯:沫朵 川北在線核心提示:原標題:《我的世界手遊》沙漠堡壘建築建造教程 手把手教你打造逼格沙漠城堡 我的世界手遊沙漠堡壘怎麼建造?
  • 不要再在JavaScript中寫 CSS了
    Ajax 的出現(2005)是一個重要的裡程碑。這時 Prototype、jQuery、MooTools 等庫已經吸引了大量的擁護者,共同解決後臺跨瀏覽器數據獲取問題。這又引發了新的問題:如何管理數據? 到了 2010 年,Backbone.js 出現,成為了應用狀態管理的行業標準。不久後,Knockout 和 Angular 雙向綁定的特點吸引了所有人。