可訪問圖標的工作SVG工作流程
>通常由於渲染不一致,可訪問性問題和語義限製而使用圖標字體通常不建議使用。 本文概述了用於創建和實現可訪問的SVG圖標的簡化工作流程,利用SVG Sprites的功能。
雖然SVG看起來很複雜,但這種方法簡化了過程。我們將利用隨時可用的圖標,並自動化Sprite生成來進行高效的管理。 鍵優點:避免了圖標字體的陷阱。
- >用自動精靈生成簡化了SVG管理。 提供了易於重複使用的圖標組件。
- 通過使用
- >和 標籤來確定可訪問性。
- >
<title></title>
<desc></desc>
工作流程概述:
源圖標:
- 獲取svg圖標(例如,來自icomoon)。 清理SVG文件,刪除不必要的元數據以最大程度地減少Sprite的尺寸。
- Sprite生成:
- >使用之類的工具(可通過npm:安裝)從您的單個圖標文件中生成SVG Sprite。 這將所有圖標整合到一個文件中以進行有效的加載。 示例命令:
spritesh
npm install spritesh -g
spritesh --input assets/images/icons --output _includes/sprite.svg --viewbox "0 0 16 16" --prefix icon-
> > sprite包含: - >在您的主佈局中包括生成的精靈(例如,在jekyll中使用)。 >
{% include sprite.svg %}
> 圖標組件: - 和可訪問性屬性。
可訪問性:
<use></use>
圖標組件應包括viewBox
和 標籤,以為屏幕讀取器提供上下文,從而增強可訪問性。 這些描述應針對特定於上下文,並根據圖標的用法動態添加。 - >
<title></title>
<desc></desc>
>
>
示例圖標組件(react):
{% capture id %}{% increment uniqueid %}{% endcapture %} <svg viewBox="0 0 16 16" role="img" class="icon icon-{{ include.icon }}" aria-labelledby="{% if include.title %}title-{{ id }}{% endif %}{% if include.desc %} desc-{{ id }}{% endif %}"> {% if include.title %} <title id="title-{{ id }}">{{ include.title }}</title> {% endif %} {% if include.desc %} <desc id="desc-{{ id }}">{{ include.desc }}</desc> {% endif %} <use xlink:href="#icon-{{ include.icon }}"></use> </svg>
登入後複製
集成像svgo()這樣的工具,以優化SVG文件,以提高性能,以提高性能。 使用NPM腳本來自動化此過程。 >
>此工作流提供了一個可靠,可維護且可訪問的解決方案,用於管理項目中的SVG圖標。請記住,請始終在不同的瀏覽器和屏幕讀取器上測試您的圖標,以確保最佳可訪問性。import { uniqueId } from 'lodash'; const Icon = (props) => { const id = uniqueId(); return ( <svg role="img" viewBox="0 0 16 16" className={`icon icon-${props.icon}`} aria-labelledby={ (props.title ? `title-${id}` : '') + (props.desc ? ` desc-${id}` : '') }> {props.title && <title id={`title-${id}`}>{props.title}</title>} {props.desc && <desc id={`desc-${id}`}>{props.desc}</desc>} <use xlinkHref={`#icon-${props.icon}`} /> </svg> ); }; export default Icon;
登入後複製
以上是可訪問圖標的工作SVG工作流程的詳細內容。更多資訊請關注PHP中文網其他相關文章!
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章
如何修復KB5055523無法在Windows 11中安裝?
3 週前
By DDD
如何修復KB5055518無法在Windows 10中安裝?
3 週前
By DDD
<🎜>:死鐵路 - 如何馴服狼
4 週前
By DDD
R.E.P.O.的每個敵人和怪物的力量水平
3 週前
By 尊渡假赌尊渡假赌尊渡假赌
<🎜>:種植花園 - 完整的突變指南
2 週前
By DDD

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

您是否曾經在項目上需要一個倒計時計時器?對於這樣的東西,可以自然訪問插件,但實際上更多

在元素個數不固定的情況下如何通過CSS選擇第一個指定類名的子元素在處理HTML結構時,常常會遇到元素個數不�...

關於Flex佈局中紫色斜線區域的疑問在使用Flex佈局時,你可能會遇到一些令人困惑的現象,比如在開發者工具(d...

格子呢是一塊圖案布,通常與蘇格蘭有關,尤其是他們時尚的蘇格蘭語。在Tartanify.com上,我們收集了5,000多個格子呢
