你知道SVG Sprites是什麼嗎,還在用css sprite就太low了

該如何以正確的姿式插入SVG Sprites?本文由@IT·平頭哥聯盟-梅斌的專欄,首席填坑官∙蘇南的專欄

  你們好,這裏是@IT·平頭哥聯盟,我是首席填坑官——蘇南(South·Su),今天要給你們分享的是SVG Sprites(也叫雪碧圖),所謂雪碧圖,固然就不是咱們常喝的雪碧飲料(Sprites)哦,哈哈~css

  當下流程的移動端,手機型號太多太多,今天工做項目中忽然發現還有同事在使用之前你們 曾經包括如今還很熟悉的CSS 圖片精靈,被咱們的測試MM找來講圖片在iphone六、iphone plus、iphone x等大屏的手機全糊了,當時我就懵逼了,我說怎麼會呢,後面一看,果真如此啊,看了下代碼,原來是用的圖片,我說爲何不用svg呢??而後同事說一個一個的圖標好麻煩,我說能夠用svg sprite啊,~~>﹏<,這個時候輪到同事一臉懵逼了……,因此想着多是不是一樣還有不少同窗也不知道SVG symbols呢,那麼這就給你們分享一下:前端

SVG英文全稱爲( Scalable Vector Graphics),意思爲可縮放的矢量圖形。它是基於XML(Extensible Markup Language),由World Wide Web Consortium(W3C)聯盟進行開發的。嚴格來講應該是一種開放標準的矢量圖形語言,可以讓你設計激動人心的、高分辨率的Web圖形頁面。SVG是一種採用XML來描述二維圖形的語言這個你們都知道,那麼symbol元素是什麼呢?單純翻譯的話,是「符號」的意思,然個人理解是symbol元素用來定義一個圖形模板對象,它能夠用一個<use>元素實例化。symbol元素對圖形的做用是在同一文檔中屢次使用,添加結構和語義,SVG是不管如何放大縮小都不會糊,而圖片當展現的尺寸大於圖片自己,就會糊了,糊了,糊了……git

本文由@IT·平頭哥聯盟-首席填坑官∙蘇南分享,梅斌的專欄,首席填坑官∙蘇南的專欄

<div class="icon-sprite"></div>
.icon-sprite {
    width: 45px;
    height: 45px;
    background-image: url(https://github.com/meibin08/img/sprite_icon.png);
    background-size: 100px 350px;
    background-position: 0 -60px;//**重點在於它**
    background-repeat: no-repeat;
}

  在之前咱們爲了性能優化,多圖標合在一張圖上面,而後再使用css的 background-position,來定位,
好處是減小了頁面的加載,要命的問題是定位遇到兼容問題,1px.5px誤差時,搞的你死去活來,後來移動端更是不清晰,被人罵了又罵。github

  當後來有一天,在一個月黑風高、暴雨傾盆、雷電交加的夜晚,我獨自一人漫步在一片小樹林裏,後來我發現了新大陸————SVG,固然若是僅僅svg就我也就不會拿出來吹水,由於確定是會被人噴的一臉口水的,可是若是再加上它的小弟——symbols? SVG symbols、SVG symbols、SVG symbols 重要的事說三遍不過份吧,雙重組合(屠龍、倚天)試問天下誰敢它爭鋒?特別是SVG它還下面還有不少小弟哦~,……有點扯遠了;這項技術基於兩個元素的使用:<symbol><use>面試

從ps或者Illustrator建立並導出SVG圖標,源碼大概是這樣的:小程序

<svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" viewBox="0 0 1024 1024"> 
    <path style="fill-rule: evenodd;" d="M941.714 512q0 143.433-83.712 258.011t-216.283 158.574q-15.433 2.853-22.565-3.986t-7.131-17.152v-120.576q0-55.442-29.696-81.152 32.585-3.438 58.587-10.277t53.723-22.272 46.299-37.998 30.281-60.014 11.703-86.016q0-69.157-45.129-117.723 21.138-52.005-4.571-116.553-16.018-5.157-46.299 6.29t-52.553 25.161l-21.723 13.714q-53.138-14.848-109.714-14.848t-109.714 14.848q-9.143-6.29-24.283-15.433t-47.726-22.016-49.152-7.717q-25.161 64.585-3.986 116.553-45.129 48.567-45.129 117.723 0 48.567 11.703 85.723t29.989 60.014 46.007 38.29 53.723 22.272 58.587 10.277q-22.857 20.553-28.014 58.843-11.995 5.705-25.71 8.558t-32.585 2.853-37.413-12.288-31.707-35.73q-10.862-18.286-27.721-29.696t-28.27-13.714l-11.447-1.719q-11.995 0-16.567 2.56t-2.853 6.583 5.157 8.009 7.424 6.839l3.986 2.853q12.581 5.705 24.869 21.723t17.993 29.147l5.705 13.129q7.424 21.723 25.161 35.145t38.29 17.152 39.717 3.986 31.707-2.011l13.129-2.304q0 21.723 0.293 50.871t0.293 30.866q0 10.277-7.424 17.152t-22.857 3.986q-132.571-43.995-216.283-158.574t-83.712-258.011q0-119.442 58.843-220.27t159.707-159.707 220.27-58.843 220.27 58.843 159.707 159.707 58.843 220.27z" p-id="3347" />
</svg>

重點來了,那麼咱們用symbols包裝後是這個樣子的:瀏覽器

<svg xmlns="http://www.w3.org/2000/svg">
  <symbol id="svg-github"  viewBox="0 0 1024 1024">
    <title>github</title>
    <path style="fill-rule: evenodd;" d="M941.714 512q0 143.433-83.712 258.011t-216.283 158.574q-15.433 2.853-22.565-3.986t-7.131-17.152v-120.576q0-55.442-29.696-81.152 32.585-3.438 58.587-10.277t53.723-22.272 46.299-37.998 30.281-60.014 11.703-86.016q0-69.157-45.129-117.723 21.138-52.005-4.571-116.553-16.018-5.157-46.299 6.29t-52.553 25.161l-21.723 13.714q-53.138-14.848-109.714-14.848t-109.714 14.848q-9.143-6.29-24.283-15.433t-47.726-22.016-49.152-7.717q-25.161 64.585-3.986 116.553-45.129 48.567-45.129 117.723 0 48.567 11.703 85.723t29.989 60.014 46.007 38.29 53.723 22.272 58.587 10.277q-22.857 20.553-28.014 58.843-11.995 5.705-25.71 8.558t-32.585 2.853-37.413-12.288-31.707-35.73q-10.862-18.286-27.721-29.696t-28.27-13.714l-11.447-1.719q-11.995 0-16.567 2.56t-2.853 6.583 5.157 8.009 7.424 6.839l3.986 2.853q12.581 5.705 24.869 21.723t17.993 29.147l5.705 13.129q7.424 21.723 25.161 35.145t38.29 17.152 39.717 3.986 31.707-2.011l13.129-2.304q0 21.723 0.293 50.871t0.293 30.866q0 10.277-7.424 17.152t-22.857 3.986q-132.571-43.995-216.283-158.574t-83.712-258.011q0-119.442 58.843-220.27t159.707-159.707 220.27-58.843 220.27 58.843 159.707 159.707 58.843 220.27z" p-id="3347" />
 </symbol>
</svg>

那麼問題來了,咱們直接在頁面上引用嗎?結果是否認的,什麼都不會顯示:性能優化

<body>
        <svg xmlns="http://www.w3.org/2000/svg">
          <symbol id="svg-github"  viewBox="0 0 1024 1024">
            <title>github</title>
            <path style="fill-rule: evenodd;" d="M941.714 512q0 143.433-83.712 258.011t-216.283 158.574q-15.433 2.853-22.565-3.986t-7.131-17.152v-120.576q0-55.442-29.696-81.152 32.585-3.438 58.587-10.277t53.723-22.272 46.299-37.998 30.281-60.014 11.703-86.016q0-69.157-45.129-117.723 21.138-52.005-4.571-116.553-16.018-5.157-46.299 6.29t-52.553 25.161l-21.723 13.714q-53.138-14.848-109.714-14.848t-109.714 14.848q-9.143-6.29-24.283-15.433t-47.726-22.016-49.152-7.717q-25.161 64.585-3.986 116.553-45.129 48.567-45.129 117.723 0 48.567 11.703 85.723t29.989 60.014 46.007 38.29 53.723 22.272 58.587 10.277q-22.857 20.553-28.014 58.843-11.995 5.705-25.71 8.558t-32.585 2.853-37.413-12.288-31.707-35.73q-10.862-18.286-27.721-29.696t-28.27-13.714l-11.447-1.719q-11.995 0-16.567 2.56t-2.853 6.583 5.157 8.009 7.424 6.839l3.986 2.853q12.581 5.705 24.869 21.723t17.993 29.147l5.705 13.129q7.424 21.723 25.161 35.145t38.29 17.152 39.717 3.986 31.707-2.011l13.129-2.304q0 21.723 0.293 50.871t0.293 30.866q0 10.277-7.424 17.152t-22.857 3.986q-132.571-43.995-216.283-158.574t-83.712-258.011q0-119.442 58.843-220.27t159.707-159.707 220.27-58.843 220.27 58.843 159.707 159.707 58.843 220.27z" p-id="3347" />
         </symbol>
        </svg>
    </body>

本文由平頭哥聯盟-首席填坑官∙蘇南分享

那麼該如何擺正姿式,正確的使用它呢?高潮部分來了:iphone

本文由平頭哥聯盟-首席填坑官∙蘇南分享

本文由平頭哥聯盟-首席填坑官∙蘇南分享

本文由平頭哥聯盟-首席填坑官∙蘇南分享

<body>
        <svg xmlns="http://www.w3.org/2000/svg" style="display:none">
          <symbol id="svg-github"  viewBox="0 0 1024 1024">
            <title>github</title>
            <path  d="M941.714 512q0 143.433-83.712 258.011t-216.283 158.574q-15.433 2.853-22.565-3.986t-7.131-17.152v-120.576q0-55.442-29.696-81.152 32.585-3.438 58.587-10.277t53.723-22.272 46.299-37.998 30.281-60.014 11.703-86.016q0-69.157-45.129-117.723 21.138-52.005-4.571-116.553-16.018-5.157-46.299 6.29t-52.553 25.161l-21.723 13.714q-53.138-14.848-109.714-14.848t-109.714 14.848q-9.143-6.29-24.283-15.433t-47.726-22.016-49.152-7.717q-25.161 64.585-3.986 116.553-45.129 48.567-45.129 117.723 0 48.567 11.703 85.723t29.989 60.014 46.007 38.29 53.723 22.272 58.587 10.277q-22.857 20.553-28.014 58.843-11.995 5.705-25.71 8.558t-32.585 2.853-37.413-12.288-31.707-35.73q-10.862-18.286-27.721-29.696t-28.27-13.714l-11.447-1.719q-11.995 0-16.567 2.56t-2.853 6.583 5.157 8.009 7.424 6.839l3.986 2.853q12.581 5.705 24.869 21.723t17.993 29.147l5.705 13.129q7.424 21.723 25.161 35.145t38.29 17.152 39.717 3.986 31.707-2.011l13.129-2.304q0 21.723 0.293 50.871t0.293 30.866q0 10.277-7.424 17.152t-22.857 3.986q-132.571-43.995-216.283-158.574t-83.712-258.011q0-119.442 58.843-220.27t159.707-159.707 220.27-58.843 220.27 58.843 159.707 159.707 58.843 220.27z" p-id="3347" />
         </symbol>
        </svg>
        一、使用方式一
        <svg class="svg-icon">
          <use xmlns:xlink="http://www.w3.org/1999/xlink" xlink:href="#svg-github" />
        </svg>
        二、使用方式二,外鏈式引入
        <svg class="svg-icon2">
          <use xmlns:xlink="http://www.w3.org/1999/xlink" xlink:href="./icon.svg#svg-github" />
        </svg>
        <style>
            .svg-icon2{
                fill:#06c; //還能夠設置圖標的種顏色哦
            }
        </style>
    </body>

爲何圖標會顯示呢?由於要顯示圖標,咱們還須要使用<use>元素,
通俗的講就是你定義了一組圖形對象(使用<symbol>元素)以後,可使用<use>元素來對它進行無限次實例化展現。你使用xlink:href屬性來指定你想要展現哪一組圖標(至關於css圖片精靈中的background-position),這裏,咱們要展現的是id爲#svg-github的<symbol>,前端性能

你們可能還發現了style="display:none",你能夠把它理解爲是css sprite裏的圖片base64轉化後的文件,而方法二裏的xlink:href="./icon.svg#svg-github",能夠理解爲是css sprite裏咱們background-image 引入圖片同樣,而 #svg-github 就是background-position裏的座標,
還有顏色的改變,咱們能夠直接在svg內的 path上寫行內式 fill="#06c"、style="fill:#06c";都是能夠的,在維護上,是否是比圖片更加方便呢???

固然啦,你們都懂的,越漂亮的妹子追的人越多啦,代碼也同樣,越好用的東西每每也是不可能那麼完美啦,看到這裏,是否是以爲想罵娘呢?白看你說這麼多廢話,最後不能用,坑爹……
別慌,其實也沒有那麼糟糕啦 ,SVG只在IE9以上支持;因此若是你須要支持IE8及如下的瀏覽器,你須要另外再寫一套降級(例如,使用png圖片方案),隨着科技的發展,IE9以上大多數人仍是能接受啦,特別是手機端的用戶,不再用擔憂測試MM來找你,圖標不清晰的問題了啦,是否是很開心,有沒有~~

總結:
svg sprites相比css sprites,不論是在維護和開發的過程當中,仍是在用戶體驗、性能、項目迭代代碼維護上都比css sprites方便,更高效便捷;

svg sprites優缺點:
  • svg sprites使用xlink:href #id的方式獲取,便於維護和擴展,由於小圖的id不會隨便改動;
  • 方便改變圖片顏色,經過設置fill:顏色值,隨意改變小圖顏色;
  • IE9以上支持。
css sprites優缺點:
  • css sprites使用background-position不便於維護和擴展、定位不精確等問題,例如:在後期項目迭代中咱們須要刪除其中一個小圖,那麼排在它後面的小圖位置都要移動,須要再次修改csss樣式,或每次都要打開PS刪除某圖標再導出;
  • 沒法修改小圖顏色,要UI設計師調整後替換,過程漫長效率低;
  • 在移動端的大屏手機圖標會模糊,影響體驗。

本文由@IT·平頭哥聯盟-首席填坑官∙蘇南分享

  以上就是今天的分享,寫了蠻久,最近纔在開始嘗試寫博客,新手上路中,若是文章中有不對之處,煩請各位大神斧正。若是你以爲這篇文章對你有所幫助,請記得點贊哦~,如以爲不錯,記得關注咱們的公衆號哦!!

寶劍鋒從磨礪出,梅花香自苦寒來,作有溫度的攻城獅,公衆號:honeyBadger8,!本文由@IT·平頭哥聯盟-首席填坑官∙蘇南分享,@IT·平頭哥聯盟 主要分享前端、測試 等領域的積累,文章來源於(本身/羣友)工做中積累的經驗、填過的坑,但願能盡綿薄之力 助其餘同窗少走一些彎路

更多文章:

作完小程序項目、老闆給我加了6k薪資~
面試踩過的坑,都在這裏了~
你應該作的前端性能優化之總結大全!
手把手教你如何繪製一輛會跑車
如何用CSS3畫出懂你的3D魔方?
immutability因React官方出鏡之使用總結分享!

做者:蘇南 - 首席填坑官
交流羣:912594095,公衆號: honeyBadger8
本文原創,著做權歸做者全部。商業轉載請聯繫 @IT·平頭哥聯盟得到受權,非商業轉載請註明原連接及出處。
相關文章
相關標籤/搜索