天天看點

移動端小圖示模糊問題

上篇文章講到 圖檔和文字垂直方向不對齊的問題 ,其中舉的小例子中用到了一個小圖示,這個小圖示我用的是背景圖來顯示:

.del .icon{ display: inline-block; width: 20px; height: 25px; margin-right: 5px; 
vertical-align: middle; background: url("imgs/delete.png") no-repeat center; background-size: 100%;}
           

delete.png圖示的實際大小為20px,在pc端顯示基本正常:

然而一放到手機上,哎呀!圖示怎麼變模糊了?!

ok,既然圖檔不夠清晰,那就用大一點的圖示呗,直接大小翻倍,用40px的上!

啥?還是有點模糊?

那就再大點……累不累?就沒有更好的解決方法麼?答案當然是有!

用矢量圖放上,也就是SVG要出場了!

當然,SVG的具體文法本文就不詳述了,這裡就簡單講講上述例子如何直接将PNG位圖換成SVG矢量圖:

1、點選進入

IcoMoon

,搜尋關鍵詞delete

2、選中删除圖示

3、再點選底部左側按鈕切換到新頁面

4、此時可以點選圖示下方的文字“Get Code”,彈出對話框

對話框

5、先将Symbol Definition(s)部分代碼取出,放在body内最前面的div中,div設定隐藏;再将HTML部分(SVG)取出代替原有PNG圖示;最後将CSS部分取出(根據需求稍做修改,如大小)放入樣式表。

<!--HTML部分-->
<body>
    <div style="display: none;">
        <!--作為一個可以按需取用的SVG庫-->
        <svg>
            <symbol id="icon-bin" viewBox="0 0 32 32">
                <title>bin</title>
                <path d="M4 10v20c0 1.1 0.9 2 2 2h18c1.1 0 2-0.9 2-2v-20h-22zM10 28h-2v-14h2v14zM14 28h-2v-14h2v14zM18 28h-2v-14h2v14zM22 28h-2v-14h2v14z"></path>
                <path d="M26.5 4h-6.5v-2.5c0-0.825-0.675-1.5-1.5-1.5h-7c-0.825 0-1.5 0.675-1.5 1.5v2.5h-6.5c-0.825 0-1.5 0.675-1.5 1.5v2.5h26v-2.5c0-0.825-0.675-1.5-1.5-1.5zM18 4h-6v-1.975h6v1.975z"></path>
            </symbol>
        </svg>
    </div>
    <div class="del"><svg class="icon icon-bin"><use xlink:href="#icon-bin"></use></svg><!--此處根據圖示id按需調用--><span>删除</span></div>
</body>
           
/*CSS部分*/
.del{ font-size: 20px;}
.del .icon{ display: inline-block; width: 20px; height: 25px; margin-right: 5px; vertical-align: middle; fill: currentColor;}
.del span{ vertical-align: middle;}
           

以上CSS部分就不做解釋了,這裡簡單說下HTML部分。

上面隐藏的那部分SVG可以看做是一個SVG庫,你可以将頁面中需要用到的SVG圖示都放在這裡面,其中每個symbol代表一個SVG圖示,然後在你需要使用圖示的地方使用通過xlink:href的方式根據id調用就好了,這個專業術語叫SVG Sprites,感覺比CSS Sprites友善多了,而且最關鍵是矢量圖,怎麼放大縮小都不失真。

舉個栗子吧~~

假如我現在需要把上面的圖示換掉,改成一個“×”,而又想保留之前圖示做備用,怎麼辦?

很簡單,直接将“×”的SVG代碼添加到“SVG庫”中就好了,就像醬紫:

<div style="display: none;">
    <!--作為一個可以按需取用的SVG庫-->
    <svg>
        <symbol id="icon-bin" viewBox="0 0 32 32">
            <title>bin</title>
            <path d="M4 10v20c0 1.1 0.9 2 2 2h18c1.1 0 2-0.9 2-2v-20h-22zM10 28h-2v-14h2v14zM14 28h-2v-14h2v14zM18 28h-2v-14h2v14zM22 28h-2v-14h2v14z"></path>
            <path d="M26.5 4h-6.5v-2.5c0-0.825-0.675-1.5-1.5-1.5h-7c-0.825 0-1.5 0.675-1.5 1.5v2.5h-6.5c-0.825 0-1.5 0.675-1.5 1.5v2.5h26v-2.5c0-0.825-0.675-1.5-1.5-1.5zM18 4h-6v-1.975h6v1.975z"></path>
        </symbol>
        <!--新增圖示-->
        <symbol id="icon-cross" viewBox="0 0 32 32">
            <title>cross</title>
            <path d="M31.708 25.708c-0-0-0-0-0-0l-9.708-9.708 9.708-9.708c0-0 0-0 0-0 0.105-0.105 0.18-0.227 0.229-0.357 0.133-0.356 0.057-0.771-0.229-1.057l-4.586-4.586c-0.286-0.286-0.702-0.361-1.057-0.229-0.13 0.048-0.252 0.124-0.357 0.228 0 0-0 0-0 0l-9.708 9.708-9.708-9.708c-0-0-0-0-0-0-0.105-0.104-0.227-0.18-0.357-0.228-0.356-0.133-0.771-0.057-1.057 0.229l-4.586 4.586c-0.286 0.286-0.361 0.702-0.229 1.057 0.049 0.13 0.124 0.252 0.229 0.357 0 0 0 0 0 0l9.708 9.708-9.708 9.708c-0 0-0 0-0 0-0.104 0.105-0.18 0.227-0.229 0.357-0.133 0.355-0.057 0.771 0.229 1.057l4.586 4.586c0.286 0.286 0.702 0.361 1.057 0.229 0.13-0.049 0.252-0.124 0.357-0.229 0-0 0-0 0-0l9.708-9.708 9.708 9.708c0 0 0 0 0 0 0.105 0.105 0.227 0.18 0.357 0.229 0.356 0.133 0.771 0.057 1.057-0.229l4.586-4.586c0.286-0.286 0.362-0.702 0.229-1.057-0.049-0.13-0.124-0.252-0.229-0.357z"></path>
        </symbol>
    </svg>
</div>
<div class="del"><svg class="icon icon-bin"><use xlink:href="#icon-cross"><!--注意這裡id名稱換了哦--></use></svg><span>删除</span></div>
           

然後就變成下面這樣,替換成功!

本文為原創文章,轉載請注明出處,謝謝!