Reputation: 2877
Using "vue-svg-loader" method to the letter in the module's docs, I get this error:
[Vue warn]: Invalid Component definition: ...
My code is identical to the example.
Any idea why I'm getting such error?
(note that previously I tried to use the code from this answer and didn't get error, however a string "..." was rendered on the page instead of the actual SVG image)
EDIT: below is my template's code, in /components/global/SvgIcon.vue
.
<template>
<ArrowRight />
</template>
<script>
import ArrowRight from '~/assets/img/arrow-right.svg?inline'
export default {
components: {
ArrowRight
}
}
</script>
And my SVG icon is in /assets/img/
.
SVG file content:
<svg width="13" height="20" viewBox="0 0 13 20" fill="none" xmlns="http://www.w3.org/2000/svg">
<path d="M12.3604 9.93625C12.3604 10.2924 12.2231 10.6485 11.9492 10.9201L3.32384 19.4648C2.77517 20.0083 1.88558 20.0083 1.33712 19.4648C0.788667 18.9214 0.788667 18.0403 1.33712 17.4967L8.96929 9.93625L1.33739 2.37573C0.788933 1.83218 0.788933 0.951159 1.33739 0.407866C1.88585 -0.135954 2.77543 -0.135954 3.32411 0.407865L11.9494 8.95245C12.2234 9.22412 12.3604 9.58023 12.3604 9.93625Z" fill="white"/>
</svg>
Upvotes: 5
Views: 5641
Reputation: 9130
Have a look at your nuxt.config.js
config file and add a reference to module @nuxtjs/svg
(as described in the Installation section in the module's doc)
I've tested it by on a minimal project (nuxt hello world example + @nuxtjs/svg). Initially it worked ok and rendered the image correctly. After removing the module reference, I got the same error message as you've described.
Upvotes: 4