I'm trying to use Font Awesome with Vue 3.
I have it in my package.json
"dependencies": {
"@fortawesome/fontawesome-svg-core": "^1.2.34",
"@fortawesome/free-brands-svg-icons": "^5.15.2",
"@fortawesome/free-solid-svg-icons": "^5.15.2",
"@fortawesome/vue-fontawesome": "^3.0.0-3",
}
Imported FontAwesome in main.js
import { createApp } from "vue";
import App from "./App.vue";
import router from "./router";
import store from "./store";
import { library } from "@fortawesome/fontawesome-svg-core";
import { faPhone } from "@fortawesome/free-solid-svg-icons/faAddressBook";
import { FontAwesomeIcon } from "@fortawesome/vue-fontawesome";
library.add(faPhone);
/* eslint-disable */
createApp(App)
.use(store)
.use(router)
.component("font-awesome-icon", FontAwesomeIcon)
.mount("#app")
And this inside component in <template>
<font-awesome-icon :icon="['fas', 'faPhone']" />
But when I use it in component nothing is happening... In element is doent's render anything it only shows HTML comment<!---->
How can I fix this problem and start using FontAwesome in any Component?
To add a Google Font to a Vue. js component, we can imnport it in our CSS. @import url("https://fonts.googleapis.com/css?family=Roboto+Condensed"); Then we can set the font-family to Roboto in the elements we want.
The <font-awesome-icon :icon="['fas', 'envelope']"/> is generated by nuxtjs/fontawesome module to call Font Awesome icons. Every time you need to add an icon, you need to use this tag. 'fas' stands for font awesome solid , which is the set we installed earlier along with font awesome brands .
These steps got it working for me:
Install prelease
(3.0.0-4
) of vue-fontawesome
, which is compatible with Vue 3, and the icon dependencies:
npm i --save @fortawesome/vue-fontawesome@prerelease
npm i --save @fortawesome/fontawesome-svg-core
npm i --save @fortawesome/free-solid-svg-icons
In main.js
, select the icons from @fortawesome/free-solid-svg-icons
to load:
import { library } from "@fortawesome/fontawesome-svg-core";
import { faPhone } from "@fortawesome/free-solid-svg-icons";
library.add(faPhone);
Globally register the font-awesome-icon
component:
import { FontAwesomeIcon } from "@fortawesome/vue-fontawesome";
createApp(App)
.component("font-awesome-icon", FontAwesomeIcon)
.mount("#app");
In src/App.vue
, use the component like this (note the icon name is phone
, not faPhone
):
<!-- explicit style -->
<font-awesome-icon :icon="['fas', 'phone']" />
<!-- implicit style (fas is assumed) -->
<font-awesome-icon icon="phone" />
demo
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With