在這里主要介紹的是阿里巴巴的矢量圖標(biāo)管理網(wǎng)站(Iconfont.cn)灌曙,它也是國(guó)內(nèi)首家推廣Webfont形式圖標(biāo)的平臺(tái)外傅。Iconfont平臺(tái)為用戶(hù)提供在線圖標(biāo)搜索摸袁、圖標(biāo)分撿下載婉称、在線儲(chǔ)存忙迁、矢量格式轉(zhuǎn)換设预、個(gè)人圖標(biāo)庫(kù)管理及項(xiàng)目圖標(biāo)管理等基礎(chǔ)功能徙歼。在這里分三點(diǎn)進(jìn)行說(shuō)明。
一、圖標(biāo)制作制作
設(shè)計(jì)師同學(xué)可以根據(jù)官方提供的設(shè)計(jì)規(guī)范進(jìn)行制作魄梯,工具是AI桨螺,制作完成導(dǎo)出的時(shí)候需要另存為SVG格式。
制作完成就需要進(jìn)行下一步上傳操作酿秸。
二灭翔、個(gè)人圖標(biāo)管理
Iconfont.cn支持設(shè)計(jì)自己上傳圖標(biāo)、收藏圖標(biāo)以及管理項(xiàng)目圖標(biāo)辣苏。
1肝箱、上傳圖標(biāo)
在iconfont.cn平臺(tái)的導(dǎo)航上有一個(gè)[圖片上傳失敗...(image-e97543-1548557083453)] <span style="text-decoration:underline;">上傳圖標(biāo)</span> 入口,點(diǎn)擊該入口進(jìn)入上傳流程稀蟋,選擇您要上傳的SVG格式圖標(biāo)煌张。
由于圖標(biāo)存在iconfont.cn平臺(tái)上搜索需要通過(guò)關(guān)鍵詞和tag才能查詢(xún)到圖標(biāo),所以在上傳圖標(biāo)的時(shí)候需要命名圖標(biāo)的名字和定義圖標(biāo)的tag退客。
2骏融、管理圖標(biāo)
打開(kāi)首頁(yè)導(dǎo)航的‘圖標(biāo)管理’按鈕,進(jìn)入圖標(biāo)管理界面井辜,以供查看“我上傳的圖標(biāo)”绎谦、“我收藏的圖標(biāo)”管闷、“項(xiàng)目管理圖標(biāo)”粥脚、“我的公開(kāi)圖標(biāo)庫(kù)”等分類(lèi)。
用戶(hù)可以在這里上傳刪除圖標(biāo)包个,收藏圖標(biāo)刷允,進(jìn)行圖標(biāo)的分類(lèi)管理。圖標(biāo)分類(lèi)管理是為了在實(shí)際項(xiàng)目中應(yīng)用碧囊,這也是這篇博客的重點(diǎn)树灶。
三、圖標(biāo)應(yīng)用
fontIcons對(duì)于前端應(yīng)用來(lái)說(shuō)有很多便捷:
- 只有變化大信炊天通;
- 自由改變顏色;
- 可以添加一些視覺(jué)效果熄驼,如陰影像寒、旋轉(zhuǎn)、透明度等等css3效果瓜贾;
- 兼容IE6诺祸。
下面介紹圖標(biāo)應(yīng)用的步驟:
1、搜索圖標(biāo)
搜索找到自己需要的圖標(biāo)祭芦,點(diǎn)擊會(huì)進(jìn)入右上角的購(gòu)物車(chē)中(可多選)筷笨,見(jiàn)下圖
[圖片上傳失敗...(image-87cc37-1548557083453)]
2、項(xiàng)目管理
點(diǎn)擊存儲(chǔ)為項(xiàng)目,輸入項(xiàng)目名稱(chēng),如"mui-icon-add",點(diǎn)擊存儲(chǔ)后,會(huì)跳轉(zhuǎn)到項(xiàng)目管理頁(yè)面.
3、下載字體
點(diǎn)擊下載到本地,會(huì)將合并后的字體文件和自動(dòng)生成的css文件全部下載到本地.
4胃夏、修改css
默認(rèn)的如下:
<pre class=" prettyprint css prettyprinted"><code><span class="lit">@font</span><span class="pun">-</span><span class="pln">face </span><span class="pun">{</span><span class="pln">font</span><span class="pun">-</span><span class="pln">family</span><span class="pun">:</span><span class="pln"> </span><span class="str">"iconfont"</span><span class="pun">;</span>
<span class="pln">
src</span><span class="pun">:</span><span class="pln"> url</span><span class="pun">(</span><span class="str">'iconfont.eot'</span><span class="pun">);</span><span class="pln"> </span><span class="com">/* IE9/</span>
<span class="pln">
src</span><span class="pun">:</span><span class="pln"> url</span><span class="pun">(</span><span class="str">'iconfont.eot?#iefix'</span><span class="pun">)</span><span class="pln"> format</span><span class="pun">(</span><span class="str">'embedded-opentype'</span><span class="pun">),</span><span class="pln"> </span><span class="com">/ IE6-IE8 /</span>
<span class="pln">
url</span><span class="pun">(</span><span class="str">'iconfont.woff'</span><span class="pun">)</span><span class="pln"> format</span><span class="pun">(</span><span class="str">'woff'</span><span class="pun">),</span><span class="pln"> </span><span class="com">/ chrome轴或、firefox /</span>
<span class="pln">
url</span><span class="pun">(</span><span class="str">'iconfont.ttf'</span><span class="pun">)</span><span class="pln"> format</span><span class="pun">(</span><span class="str">'truetype'</span><span class="pun">),</span><span class="pln"> </span><span class="com">/ chrome、firefox仰禀、opera侮叮、Safari, Android, iOS 4.2+/</span>
<span class="pln">
url</span><span class="pun">(</span><span class="str">'iconfont.svg#iconfont'</span><span class="pun">)</span><span class="pln"> format</span><span class="pun">(</span><span class="str">'svg'</span><span class="pun">);</span><span class="pln"> </span><span class="com">/ iOS 4.1- */</span>
<span class="pln">
</span><span class="pun">}</span>
<span class="pln">
</span>
<span class="pln">
</span><span class="pun">.</span><span class="pln">iconfont </span><span class="pun">{</span>
<span class="pln">
font</span><span class="pun">-</span><span class="pln">family</span><span class="pun">:</span><span class="str">"iconfont"</span><span class="pln"> </span><span class="pun">!</span><span class="pln">important</span><span class="pun">;</span>
<span class="pln">
font</span><span class="pun">-</span><span class="pln">size</span><span class="pun">:</span><span class="lit">16px</span><span class="pun">;</span>
<span class="pln">
font</span><span class="pun">-</span><span class="pln">style</span><span class="pun">:</span><span class="pln">normal</span><span class="pun">;</span>
<span class="pln">
</span><span class="pun">-</span><span class="pln">webkit</span><span class="pun">-</span><span class="pln">font</span><span class="pun">-</span><span class="pln">smoothing</span><span class="pun">:</span><span class="pln"> antialiased</span><span class="pun">;</span>
<span class="pln">
</span><span class="pun">-</span><span class="pln">webkit</span><span class="pun">-</span><span class="pln">text</span><span class="pun">-</span><span class="pln">stroke</span><span class="pun">-</span><span class="pln">width</span><span class="pun">:</span><span class="pln"> </span><span class="lit">0.2px</span><span class="pun">;</span>
<span class="pln">
</span><span class="pun">-</span><span class="pln">moz</span><span class="pun">-</span><span class="pln">osx</span><span class="pun">-</span><span class="pln">font</span><span class="pun">-</span><span class="pln">smoothing</span><span class="pun">:</span><span class="pln"> grayscale</span><span class="pun">;</span>
<span class="pln">
</span><span class="pun">}</span>
<span class="pln">
</span>
<span class="pln">
</span><span class="pun">.</span><span class="pln">icon</span><span class="pun">-</span><span class="pln">nanzhuang</span><span class="pun">:</span><span class="pln">before </span><span class="pun">{</span><span class="pln"> content</span><span class="pun">:</span><span class="pln"> </span><span class="str">"\e600"</span><span class="pun">;</span><span class="pln"> </span><span class="pun">}</span>
<span class="pln">
</span>
<span class="pln">
</span><span class="pun">.</span><span class="pln">icon</span><span class="pun">-</span><span class="pln">nvzhuang</span><span class="pun">:</span><span class="pln">before </span><span class="pun">{</span><span class="pln"> content</span><span class="pun">:</span><span class="pln"> </span><span class="str">"\e601"</span><span class="pun">;</span><span class="pln"> </span><span class="pun">}</span>
<span class="pln">
</span>
<span class="pln">
</span><span class="pun">.</span><span class="pln">icon</span><span class="pun">-</span><span class="pln">gouwuche</span><span class="pun">:</span><span class="pln">before </span><span class="pun">{</span><span class="pln"> content</span><span class="pun">:</span><span class="pln"> </span><span class="str">"\e602"</span><span class="pun">;</span><span class="pln"> </span><span class="pun">}</span>
</code></pre>
我們可稍作修改,
- 為保證和框架目錄結(jié)構(gòu)統(tǒng)一,建議將字體文件放在fonts目錄下悼瘾,這樣我們需要修改@font-face下得url屬性囊榜;
- 字體文件類(lèi)名需要和其他字體文件保持一致,方便調(diào)用亥宿。
- 只兼容iOS和Android版本的話卸勺,我們僅需要ttf格式的字體即可,其它字體可以刪除烫扼;同時(shí)曙求,我們也僅需保留-webkit前綴語(yǔ)法,-moz前綴部分可以刪除映企;
修改后的代碼如下:
<pre class=" prettyprint css prettyprinted"><code><span class="pln"> </span><span class="lit">@font</span><span class="pun">-</span><span class="pln">face </span><span class="pun">{</span><span class="pln">font</span><span class="pun">-</span><span class="pln">family</span><span class="pun">:</span><span class="pln"> </span><span class="str">"iconfont"</span><span class="pun">;</span>
<span class="pln">
src</span><span class="pun">:</span><span class="pln">url</span><span class="pun">(</span><span class="str">'../fonts/iconfont.ttf'</span><span class="pun">)</span><span class="pln"> format</span><span class="pun">(</span><span class="str">'truetype'</span><span class="pun">);</span><span class="pln"> </span><span class="com">/* chrome悟狱、firefox、opera堰氓、Safari, Android, iOS 4.2+*/</span>
<span class="pln">
</span><span class="pun">}</span>
<span class="pln">
</span>
<span class="pln">
</span><span class="pun">.</span><span class="pln">iconfont </span><span class="pun">{</span>
<span class="pln">
font</span><span class="pun">-</span><span class="pln">family</span><span class="pun">:</span><span class="str">"iconfont"</span><span class="pln"> </span><span class="pun">!</span><span class="pln">important</span><span class="pun">;</span>
<span class="pln">
font</span><span class="pun">-</span><span class="pln">size</span><span class="pun">:</span><span class="lit">16px</span><span class="pun">;</span>
<span class="pln">
font</span><span class="pun">-</span><span class="pln">style</span><span class="pun">:</span><span class="pln">normal</span><span class="pun">;</span>
<span class="pln">
</span><span class="pun">-</span><span class="pln">webkit</span><span class="pun">-</span><span class="pln">font</span><span class="pun">-</span><span class="pln">smoothing</span><span class="pun">:</span><span class="pln"> antialiased</span><span class="pun">;</span>
<span class="pln">
</span><span class="pun">-</span><span class="pln">webkit</span><span class="pun">-</span><span class="pln">text</span><span class="pun">-</span><span class="pln">stroke</span><span class="pun">-</span><span class="pln">width</span><span class="pun">:</span><span class="pln"> </span><span class="lit">0.2px</span><span class="pun">;</span>
<span class="pln">
</span><span class="pun">}</span>
<span class="pln">
</span>
<span class="pln">
</span><span class="pun">.</span><span class="pln">icon</span><span class="pun">-</span><span class="pln">nanzhuang</span><span class="pun">:</span><span class="pln">before </span><span class="pun">{</span><span class="pln"> content</span><span class="pun">:</span><span class="pln"> </span><span class="str">"\e600"</span><span class="pun">;</span><span class="pln"> </span><span class="pun">}</span>
<span class="pln">
</span>
<span class="pln">
</span><span class="pun">.</span><span class="pln">icon</span><span class="pun">-</span><span class="pln">nvzhuang</span><span class="pun">:</span><span class="pln">before </span><span class="pun">{</span><span class="pln"> content</span><span class="pun">:</span><span class="pln"> </span><span class="str">"\e601"</span><span class="pun">;</span><span class="pln"> </span><span class="pun">}</span>
<span class="pln">
</span>
<span class="pln">
</span><span class="pun">.</span><span class="pln">icon</span><span class="pun">-</span><span class="pln">gouwuche</span><span class="pun">:</span><span class="pln">before </span><span class="pun">{</span><span class="pln"> content</span><span class="pun">:</span><span class="pln"> </span><span class="str">"\e602"</span><span class="pun">;</span><span class="pln"> </span><span class="pun">}</span>
</code></pre>
將iconfont.css及iconfont.ttf兩個(gè)文件分別拷貝到mui工程css及fonts目錄下挤渐,然后即可在框架中引用剛生成的字體圖.
以mui框架為例,新增的字體應(yīng)用在標(biāo)簽內(nèi)代碼如下:
<span class="mui-icon iconfont icon-nanzhuang"></span>
以上完双絮!