当我尝试使用vue-fontawesome框架和@nuxtjs/fontawesome框架时,我遇到了一个Nuxtjs错误,这是错误:
[nuxt] [request error] Cannot read properties of undefined (reading 'component')
at $id_c50a96b3 (./.nuxt/dist/server/server.mjs:3239:31)
at async __instantiateModule__ (./.nuxt/dist/server/server.mjs:19193:3)
这是我在nuxt.config.ts
中代码:
import { defineNuxtConfig } from 'nuxt'
export default defineNuxtConfig({
modules: [
'@nuxtjs/fontawesome'
],
fontawesome: {
icons: {
solid: ['faXmark']
}
}
})
这是我想要使用图标的组件:
<template>
<div :class="props.className">
<font-awesome-icon icon="xmark" />
<slot />
</div>
</template>
顺便说一句,错误只出现在我试图加载页面时,而不是在我运行它时。
3条答案
按热度按时间qgelzfjb1#
我推荐antfu的这个解决方案,这是IMO迄今为止处理任何类型图标的最佳方法:https://github.com/antfu/unplugin-icons
检查更多的in-depth article解释为什么和如何整个事情的工作。
下面是如何将其与Nuxt 3一起使用的快速方法,首先是要求:
pnpm dlx nuxi init nuxt3-unplugin-icons
pnpm i --shamefully-hoist
pnpm add -D unplugin-icons
的包在您的
nuxt.config.ts
文件中获取此信息我不知道如何修复类型,所以我忽略了这里的检查。
完成后,您可以转到icones.js并查找您的特定图标,单击它,您将看到以下内容
注意格式是
[collection-id]:[name]
,所以在您的情况下是fa6-solid:xmark
。现在您可以转到任何
.vue
文件,并在导入时将fa6-solid:xmark
转换为~icons/fa6-solid/xmark
。您的Nuxt 3项目现在将能够自动为您安装相关的软件包。
仅此而已!🎉
这个
autoInstall
特性在大多数情况下都能工作,但并不是100%经过实战测试的。我注意到它只能同时安装2个图标包(一个简单的重新启动服务器修复了这个问题)。
如果自动安装功能失败,您可以随时转到npm,并在您的情况下查找
@iconify-json/[your collection id]
aka@iconify-json/fa6-solid
。NPM很擅长建议,从我所看到的来看,这是一个很好的建议。
下面是一个如何使用其他图标的示例
实际的结果,完全可以用CSS定制,如您所见
如果需要的话,您可以查看我的github repo以获得一个完整的工作示例。
PS:一个auto-import feature正在制作中。欢迎订阅Github PR了解更多更新。
PS2:如果你有一个预定义的图标阵列,那么它甚至可以与动态组件一起使用,这样捆绑器就可以通过分析阅读提前知道它们。
q35jwt9p2#
您还可以使用相当新的包nuxt-icon,它是由CEO of NuxtLabs创建的,并在nuxt 3/content 2启动器模板content-wind中使用。
安装
安装Nuxt 3
nuxt.config.ts
用法
只需从icones.js.org复制并粘贴你想要的图标名称。软件包将提取图标并粘贴到你的代码中。你有100 k+个图标可供选择。
disbfnqx3#
仅在使用自定义SVG图标时适用
当我使用自定义svg图标(没有图标框架)时,我通常使用vite-svg-loader。
nuxt.config.ts
安装完成后,我创建了一个新组件,以后可以在其他组件中使用它(components/IconLoader.vue):
现在,我可以轻松地显示图标与我们的新的自定义图标加载器组件(例如App.vue):
我通常从https://heroicons.dev得到我的图标,他们与顺风工作得很好。