Iconfont 在HTML中的使用

来源:https://www.cnblogs.com/hwbing/archive/2019/03/30/10629377.html
-Advertisement-
Play Games

一、準備階段: a.進入阿裡巴巴矢量圖標庫www.iconfont.cn挑選所需的圖標,加入購物車 b.點擊網頁中的購物車下載代碼 二、3種方法實現 Iconfont 的HTML顯示 Unicode 引用 Unicode 是字體在網頁端最原始的應用方式,特點是: 相容性最好,支持 IE6+,及所有現 ...


一、準備階段:

  a.進入阿裡巴巴矢量圖標庫www.iconfont.cn挑選所需的圖標,加入購物車

   

  b.點擊網頁中的購物車下載代碼

  

二、3種方法實現 Iconfont 的HTML顯示

  1. Unicode 引用

    Unicode 是字體在網頁端最原始的應用方式,特點是:

    • 相容性最好,支持 IE6+,及所有現代瀏覽器。
    • 支持按字體的方式去動態調整圖標大小,顏色等等。
    • 但是因為是字體,所以不支持多色。只能使用平臺里單色的圖標,就算項目里有多色圖標也會自動去色。

    註意:新版 iconfont 支持多色圖標,這些多色圖標在 Unicode 模式下將不能使用,如果有需求建議使用symbol 的引用方式

    使用步驟如下:
    第一步:在CSS代碼塊或CSS文件中使用 @font-face 聲明字體
    @font-face {
      font-family: 'iconfont';
      src: url('iconfont.eot');
      src: url('iconfont.eot?#iefix') format('embedded-opentype'),
          url('iconfont.woff2') format('woff2'),
          url('iconfont.woff') format('woff'),
          url('iconfont.ttf') format('truetype'),
          url('iconfont.svg#iconfont') format('svg');
    }

    第二步:定義使用 iconfont 的樣式

    .iconfont {
      font-family: "iconfont" !important;
      font-size: 16px;
      font-style: normal;
      -webkit-font-smoothing: antialiased;
      -moz-osx-font-smoothing: grayscale;
    }

    第三步:挑選相應圖標並獲取字體編碼,應用於頁面

    <span class="iconfont">&#xe612;</span>

    完整代碼:

    <!DOCTYPE html>
    <html>
    
        <head>
            <meta charset="UTF-8">
            <title></title>
            <style type="text/css">
                @font-face {
                    font-family: 'iconfont';
                    src: url('iconfont.eot');
                    src: url('iconfont.eot?#iefix') format('embedded-opentype'), url('iconfont.woff2') format('woff2'), url('iconfont.woff') format('woff'), url('iconfont.ttf') format('truetype'), url('iconfont.svg#iconfont') format('svg');
                }
                
                .iconfont {
                    font-family: "iconfont" !important;
                    font-size: 16px;
                    font-style: normal;
                    -webkit-font-smoothing: antialiased;
                    -moz-osx-font-smoothing: grayscale;
                }
            </style>
        </head>
    
        <body>
            <span class="iconfont">&#xe612;</span>
        </body>
    
    </html>

    註意:CSS代碼塊中的 @font-face 內的 src: url('iconfont.eot'); 中的 url 即為之前準備階段下載的源碼文件夾下的對應文件,此處的完整代碼的文件路徑與 iconfont.eot 在同一目錄下,若相應文件不在同一目錄下請修改url參數。
    實現效果:

  2. 2.font-class 引用

    font-class 是 Unicode 使用方式的一種變種,主要是解決 Unicode 書寫不直觀,語意不明確的問題。

    與 Unicode 使用方式相比,具有如下特點:

    1. 相容性良好,支持 IE8+,及所有現代瀏覽器。
    2. 相比於 Unicode 語意明確,書寫更直觀。可以很容易分辨這個 icon 是什麼。
    3. 因為使用 class 來定義圖標,所以當要替換圖標時,只需要修改 class 裡面的 Unicode 引用。
    4. 不過因為本質上還是使用的字體,所以多色圖標還是不支持的。
      使用步驟如下:

      第一步:引入項目下麵生成的 fontclass 代碼(即為準備階段下載的代碼文件中的iconfont.css文件)重要!!!:

      <link rel="stylesheet" href="./iconfont.css">

      第二步:挑選相應圖標並獲取類名,應用於頁面:

      <span class="iconfont icon-setup"></span>

 

   3.Symbol 引用   

這是一種全新的使用方式,應該說這才是未來的主流,也是平臺目前推薦的用法。相關介紹可以參考這篇文章 這種用法其實是做了一個 SVG 的集合,與另外兩種相比具有如下特點:

    • 支持多色圖標了,不再受單色限制。
    • 通過一些技巧,支持像字體那樣,通過 font-sizecolor 來調整樣式。
    • 相容性較差,支持 IE9+,及現代瀏覽器。
    • 瀏覽器渲染 SVG 的性能一般,還不如 png。

使用步驟如下:

    • 第一步:引入項目下麵生成的 symbol 代碼:
      <script src="./iconfont.js"></script>
    • 第二步:加入通用 CSS 代碼(引入一次就行):
      <style>
      .icon {
        width: 1em;
        height: 1em;
        vertical-align: -0.15em;
        fill: currentColor;
        overflow: hidden;
      }
      </style>
    • 第三步:挑選相應圖標並獲取類名,應用於頁面:

      <svg class="icon" aria-hidden="true">
        <use xlink:href="#icon-setup"></use>
      </svg>

三、效果展示

index.html

<!DOCTYPE html>
<html>
    <head>
        <meta charset="UTF-8">
        <meta name="viewport" content="width=device-width, initial-scale=1, shrink-to-fit=no">
        <title></title>
        <link rel="stylesheet" href="css/bootstrap.css" />
        <link rel="stylesheet" href="css/iconfont-style.css" />
    </head>
    <body>       
       <a class="btn btn-lg btn-primary"><i class="icon icon-info"></i>&nbsp;More About</a>
    </body>
</html>

iconfont-style.css

@font-face {
    font-family: 'iconfont';
    src:url('../fonts/iconfont.eot?-8vg322');
    src:url('../fonts/iconfont.eot?#iefix-8vg322') format('embedded-opentype'),
        url('../fonts/iconfont.woff?-8vg322') format('woff'),
        url('../fonts/iconfont.ttf?-8vg322') format('truetype'),
        url('../fonts/iconfont.svg?-8vg322#iconfont') format('svg');
    font-weight: normal;
    font-style: normal;
}

[class^="icon-"], [class*=" icon-"] {
    font-family: 'iconfont';
    speak: none;
    font-style: normal;
    font-weight: normal;
    font-variant: normal;
    text-transform: none;
    line-height: 1;

    /* Better Font Rendering =========== */
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

.icon-user-female:before {
    content: "\e106";
}
.icon-user-follow:before {
    content: "\e064";
}
.icon-user-following:before {
    content: "\e065";
}
更多定義的icon此處省略........

引用的 fonts 目錄下的文件:

效果圖:

更多精彩的效果圖展示:

             

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • View動畫 幀動畫 屬性動畫 幀動畫最簡單,通過順序播放一系列的圖像產生動畫,就和動畫片的原理是一樣的。做好的結果可以是這樣: 也可以是這樣的動態圖: 如果無法播放動態圖的話,可能是您的瀏覽器需要升級一下了。我們為了創建一個好的幀動畫,首先應該創建一個xml文件,用於圖片的輪播,但是這個xml文件 ...
  • 我們經常會遇到listview或者其他view設置setOnItemSelectedListener監聽時,一載入界面,setOnItemSelectedListener監聽就會自動執行一遍,導致你第一次移動上去的時候setOnItemSelectedListener監聽就不會走的 所以我們採用自定 ...
  • 1. 超鏈接邊框 2. 派生超鏈接 3. 屬性選擇器超鏈接 4. 動態超鏈接 5. 圖像翻轉超鏈接 6. CSS 工具提示 1.給鏈接加上邊框 A:link { Color: #f00; Text-decoration: none; Border-bottom: 1px dashed #333; L ...
  • 1. div 2. 邊距 3. 邊框 4. 定位 5. 浮動 1 21.1 div 部分(division) <div>元素,經常以 div 形式引用 是 XHTML 元素,用於定義 XHTML 文 件中的區域. 1.添加 div <div> <p>This is our content area. ...
  • 1.Filter 屬性介紹 2.Alpha 濾鏡的使用 3.Blur 濾鏡的使用 4.Filph、Filpv 濾鏡 5.DropShadow 濾鏡 6.Glow 濾鏡 7.Gray ,Invert,Xray 濾鏡 8.Shadow 濾鏡 1 19.1 F Fr ilter 屬性介紹 設置或檢索對象所 ...
  • dyld: Library not loaded: /usr/local/opt/jpeg/lib/libjpeg.8.dylib Referenced from: /usr/local/lib/liblept.5.dylib Reason: image not found'使用pytesserac... ...
  • 有一道很有意思的數組操作相關編程題,閑來無事用JS解決了一下,問題描述如下: (1) 鍵盤錄入6個int類型的數據存入數組arr中; (2) 將arr數組中的內容反轉; (3) 將反轉後的數組角標為奇數的元素相互交換,即1和3交換,3和5交換,以此類推; (4) 將數組中最後一個角標為奇數的元素和數 ...
  • 1. HTML認識 1.1 什麼是HTML HTML是描述(製作)網頁的語言,指的是超文本標記語言(Hyper Text Markup Language)。 超文本:就是指頁面內可以包含圖片、鏈接、甚至音樂、程式等非文字元素; 標記語言:是一套標記標簽(markup tag); 標記:一種標記符、標 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...