oh-vue-icons 使用教程
2025-04-18 13:22:24作者:廉彬冶Miranda
1. 项目介绍
oh-vue-icons 是一个 Vue 组件,用于轻松地从不同的流行图标包中导入内联 SVG 图标。它支持 Vue 2 和 Vue 3,并且可以通过 tree-shaking 只导入所需的图标,从而减少包的大小。目前支持超过 20 个流行的图标包,总共拥有 30,000 多个图标。
2. 项目快速启动
首先,您需要安装 oh-vue-icons。可以使用 npm 或 yarn:
npm install oh-vue-icons
# 或者
yarn add oh-vue-icons
对于 Vue 2 项目,还需要安装 @vue/composition-api:
npm install @vue/composition-api -D
# 或者
yarn add @vue/composition-api -D
如果使用 Nuxt 2,需要安装 @nuxtjs/composition-api 并在 nuxt.config.js 中配置:
npm install @nuxtjs/composition-api -D
# 或者
yarn add @nuxtjs/composition-api -D
然后在 nuxt.config.js 中添加:
export default {
// ...
buildModules: [
// ...
'@nuxtjs/composition-api/module'
]
}
在 Vue 3 中,您可以在 main.js 中全局导入和注册 oh-vue-icons:
import { createApp } from 'vue';
import App from './App.vue';
import { OhVueIcon, addIcons } from 'oh-vue-icons';
import { FaFlag, RiZhihuFill } from 'oh-vue-icons/icons';
addIcons(FaFlag, RiZhihuFill);
const app = createApp(App);
app.component('v-icon', OhVueIcon);
app.mount('#app');
在 Vue 2 中,注册方式稍有不同:
import Vue from 'vue';
import App from './App.vue';
import { OhVueIcon, addIcons } from 'oh-vue-icons';
import { FaFlag, RiZhihuFill } from 'oh-vue-icons/icons';
addIcons(FaFlag, RiZhihuFill);
Vue.component('v-icon', OhVueIcon);
new Vue({
render: h => h(App)
}).$mount('#app');
3. 应用案例和最佳实践
使用 oh-vue-icons 的示例,您可以按照以下方式在模板中添加图标:
<template>
<div>
<v-icon name="fa-flag" />
<v-icon name="ri-zhihu-fill" />
</div>
</template>
对于 Font Awesome 5 的图标,如果图标来自 regular 包,则属性值应为 fa-regular-flag。来自 solid 和 brands 包的图标属性值分别为 fa-beer 和 fa-github。
更多关于图标属性和用法的信息,请查看官方文档。
4. 典型生态项目
oh-vue-icons 可以与 Vue 相关的许多生态项目一起使用,例如 Nuxt.js 和 Vite。以下是一些配置示例:
- 在 Nuxt.js 中使用: 将 oh-vue-icons 添加到 nuxt.config.js 的 build.transpile 选项中。
export default {
// ...
build: {
transpile: ['oh-vue-icons']
}
}
- 在 Vite 中使用: 排除 oh-vue-icons 从预打包中,以及在服务器端渲染时添加到 ssr.noExternal 选项中。
export default {
// ...
optimizeDeps: {
exclude: ['oh-vue-icons/icons']
},
ssr: {
noExternal: ['oh-vue-icons']
}
}
通过以上步骤,您可以轻松地在项目中使用 oh-vue-icons,并利用其提供的丰富图标资源。
登录后查看全文
热门项目推荐
Kimi-K2.5Kimi K2.5 是一款开源的原生多模态智能体模型,它在 Kimi-K2-Base 的基础上,通过对约 15 万亿混合视觉和文本 tokens 进行持续预训练构建而成。该模型将视觉与语言理解、高级智能体能力、即时模式与思考模式,以及对话式与智能体范式无缝融合。Python00- QQwen3-Coder-Next2026年2月4日,正式发布的Qwen3-Coder-Next,一款专为编码智能体和本地开发场景设计的开源语言模型。Python00
xw-cli实现国产算力大模型零门槛部署,一键跑通 Qwen、GLM-4.7、Minimax-2.1、DeepSeek-OCR 等模型Go06
PaddleOCR-VL-1.5PaddleOCR-VL-1.5 是 PaddleOCR-VL 的新一代进阶模型,在 OmniDocBench v1.5 上实现了 94.5% 的全新 state-of-the-art 准确率。 为了严格评估模型在真实物理畸变下的鲁棒性——包括扫描伪影、倾斜、扭曲、屏幕拍摄和光照变化——我们提出了 Real5-OmniDocBench 基准测试集。实验结果表明,该增强模型在新构建的基准测试集上达到了 SOTA 性能。此外,我们通过整合印章识别和文本检测识别(text spotting)任务扩展了模型的能力,同时保持 0.9B 的超紧凑 VLM 规模,具备高效率特性。Python00
Baichuan-M3-235BBaichuan-M3 是百川智能推出的新一代医疗增强型大型语言模型,是继 Baichuan-M2 之后的又一重要里程碑。Python00
VLOOKVLOOK™ 是优雅好用的 Typora/Markdown 主题包和增强插件。 VLOOK™ is an elegant and practical THEME PACKAGE × ENHANCEMENT PLUGIN for Typora/Markdown.Less00
项目优选
收起
OpenHarmony documentation | OpenHarmony开发者文档
Dockerfile
539
3.76 K
Ascend Extension for PyTorch
Python
345
412
本项目是CANN提供的数学类基础计算算子库,实现网络在NPU上加速计算。
C++
888
605
openEuler内核是openEuler操作系统的核心,既是系统性能与稳定性的基石,也是连接处理器、设备与服务的桥梁。
C
337
182
暂无简介
Dart
777
192
deepin linux kernel
C
27
11
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
1.34 K
758
React Native鸿蒙化仓库
JavaScript
303
356
openJiuwen agent-studio提供零码、低码可视化开发和工作流编排,模型、知识库、插件等各资源管理能力
TSX
987
252
仓颉编译器源码及 cjdb 调试工具。
C++
154
896