Skip to content

Some SVG icons go missing on vue components #4750

Open
@bilogic

Description

@bilogic
vid.mp4

Describe the bug

Some SVGs go missing after a browser refresh (ctrl+shift+r).

After alot of trial and error, it appears to be due to the contents of the SVGs themselves (yes, sounds crazy), in this case, I demonstrate the problem using vitepress' icon and also included an icon (trash.svg) that does not cause the problem.

The telltale sign is to looking for warnings when running npm run build

As far as I can tell, this is likely due to vitepress SSR because the issue does not happen when npm run dev and also when the component used only vite + vue + vite-svg-loader.

Reproduction

https://github.com/bilogic/vitepress-missing-vue-icon

Navigate to this URL /tool/widget and follow the instructions there, can also refer to video

Expected behavior

SVG should always appear consistently, and not go missing

System Info

System:
    OS: Linux 6.8 Ubuntu 22.04.5 LTS 22.04.5 LTS (Jammy Jellyfish)
    CPU: (24) x64 Intel(R) Xeon(R) CPU E5-2680 v4 @ 2.40GHz
    Memory: 17.84 GB / 20.00 GB
    Container: Yes
    Shell: 5.1.16 - /bin/bash
  Binaries:
    Node: 23.11.0 - /usr/local/bin/node
    npm: 10.9.2 - /usr/local/bin/npm
  npmPackages:
    vitepress: ^1.6.3 => 1.6.3

Additional context

If you get this warning when running npm run build, then one of the SVGs has a problem:

vite v5.4.19 building SSR bundle for production...
"createElementVNode" is imported from external module "vue" but never used in "docs/index.md", "node_modules/vitepress/dist/client/app/components/ClientOnly.js", "node_modules/vitepress/dist/client/app/composables/preFetch.js", "node_modules/vitepress/dist/client/app/components/Content.js", "widgets/assets/vitepress.svg", "widgets/Component.vue?vue&type=script&setup=true&lang.ts", "widgets/Component.vue", "docs/tool/widget.md?vue&type=script&setup=true&lang.ts", "docs/tool/widget.md", "node_modules/vitepress/dist/client/app/data.js", "node_modules/vitepress/dist/client/app/utils.js", "node_modules/vitepress/dist/client/app/router.js", "node_modules/vitepress/dist/client/app/composables/head.js", "node_modules/vitepress/dist/client/theme-default/components/VPBadge.vue?vue&type=script&setup=true&lang.ts", "node_modules/vitepress/dist/client/theme-default/components/VPBadge.vue", "node_modules/vitepress/dist/client/theme-default/components/VPHomeContent.vue?vue&type=script&setup=true&lang.ts", "node_modules/vitepress/dist/client/theme-default/components/VPHomeContent.vue", "node_modules/vitepress/dist/client/theme-default/components/VPHomeFeatures.vue?vue&type=script&setup=true&lang.ts", "node_modules/vitepress/dist/client/theme-default/components/VPHomeFeatures.vue", "node_modules/vitepress/dist/client/theme-default/components/VPTeamPage.vue", "node_modules/vitepress/dist/client/theme-default/components/VPTeamPageSection.vue", "node_modules/vitepress/dist/client/theme-default/components/VPTeamPageTitle.vue", "node_modules/vitepress/dist/client/theme-default/components/VPHomeSponsors.vue?vue&type=script&setup=true&lang.ts", "node_modules/vitepress/dist/client/theme-default/components/VPDocAsideSponsors.vue?vue&type=script&setup=true&lang.ts", "node_modules/vitepress/dist/client/theme-default/components/VPHomeSponsors.vue", "node_modules/vitepress/dist/client/theme-default/components/VPDocAsideSponsors.vue", "node_modules/vitepress/dist/client/theme-default/components/VPImage.vue?vue&type=script&setup=true&lang.ts", "node_modules/vitepress/dist/client/theme-default/components/VPImage.vue", "node_modules/vitepress/dist/client/theme-default/components/VPSocialLinks.vue?vue&type=script&setup=true&lang.ts", "node_modules/vitepress/dist/client/theme-default/components/VPSocialLinks.vue", "node_modules/vitepress/dist/client/theme-default/components/VPLink.vue?vue&type=script&setup=true&lang.ts", "node_modules/vitepress/dist/client/theme-default/components/VPLink.vue", "node_modules/vitepress/dist/client/theme-default/composables/sidebar.js", "node_modules/vitepress/dist/client/theme-default/components/VPButton.vue?vue&type=script&setup=true&lang.ts", "node_modules/vitepress/dist/client/theme-default/components/VPButton.vue", "node_modules/vitepress/dist/client/theme-default/composables/aside.js", "node_modules/vitepress/dist/client/theme-default/composables/outline.js", "node_modules/vitepress/dist/client/theme-default/composables/local-nav.js", "node_modules/vitepress/dist/client/theme-default/components/VPSocialLink.vue?vue&type=script&setup=true&lang.ts", "node_modules/vitepress/dist/client/theme-default/components/VPSocialLink.vue", "node_modules/vitepress/dist/client/theme-default/components/VPBackdrop.vue?vue&type=script&setup=true&lang.ts", "node_modules/vitepress/dist/client/theme-default/components/VPBackdrop.vue", "node_modules/vitepress/dist/client/theme-default/components/VPSkipLink.vue?vue&type=script&setup=true&lang.ts", "node_modules/vitepress/dist/client/theme-default/components/VPSkipLink.vue", "node_modules/vitepress/dist/client/theme-default/components/VPFooter.vue?vue&type=script&setup=true&lang.ts", "node_modules/vitepress/dist/client/theme-default/components/VPFooter.vue", "node_modules/vitepress/dist/client/theme-default/components/VPFeature.vue?vue&type=script&setup=true&lang.ts", "node_modules/vitepress/dist/client/theme-default/components/VPFeature.vue", "node_modules/vitepress/dist/client/theme-default/components/VPFeatures.vue?vue&type=script&setup=true&lang.ts", "node_modules/vitepress/dist/client/theme-default/components/VPFeatures.vue", "node_modules/vitepress/dist/client/theme-default/components/VPHero.vue?vue&type=script&setup=true&lang.ts", "node_modules/vitepress/dist/client/theme-default/components/VPHero.vue", "node_modules/vitepress/dist/client/theme-default/components/VPHomeHero.vue?vue&type=script&setup=true&lang.ts", "node_modules/vitepress/dist/client/theme-default/components/VPHomeHero.vue", "node_modules/vitepress/dist/client/theme-default/components/VPTeamMembersItem.vue?vue&type=script&setup=true&lang.ts", "node_modules/vitepress/dist/client/theme-default/components/VPTeamMembersItem.vue", "node_modules/vitepress/dist/client/theme-default/components/VPTeamMembers.vue?vue&type=script&setup=true&lang.ts", "node_modules/vitepress/dist/client/theme-default/components/VPTeamMembers.vue", "node_modules/vitepress/dist/client/theme-default/components/VPPage.vue", "node_modules/vitepress/dist/client/theme-default/composables/nav.js", "node_modules/vitepress/dist/client/theme-default/components/VPHome.vue?vue&type=script&setup=true&lang.ts", "node_modules/vitepress/dist/client/theme-default/components/VPHome.vue", "node_modules/vitepress/dist/client/theme-default/composables/sponsor-grid.js", "node_modules/vitepress/dist/client/theme-default/components/VPSponsorsGrid.vue?vue&type=script&setup=true&lang.ts", "node_modules/vitepress/dist/client/theme-default/components/VPSponsorsGrid.vue", "node_modules/vitepress/dist/client/theme-default/components/VPSponsors.vue?vue&type=script&setup=true&lang.ts", "node_modules/vitepress/dist/client/theme-default/components/VPSponsors.vue", "node_modules/vitepress/dist/client/theme-default/components/VPNavBarSearchButton.vue?vue&type=script&setup=true&lang.ts", "node_modules/vitepress/dist/client/theme-default/components/VPNavBarSearchButton.vue", "node_modules/vitepress/dist/client/theme-default/components/VPNavBarSearch.vue?vue&type=script&setup=true&lang.ts", "node_modules/vitepress/dist/client/theme-default/components/VPNavBarSearch.vue", "node_modules/vitepress/dist/client/theme-default/composables/langs.js", "node_modules/vitepress/dist/client/theme-default/NotFound.vue?vue&type=script&setup=true&lang.ts", "node_modules/vitepress/dist/client/theme-default/NotFound.vue", "node_modules/vitepress/dist/client/theme-default/components/VPDocOutlineItem.vue?vue&type=script&setup=true&lang.ts", "node_modules/vitepress/dist/client/theme-default/components/VPDocOutlineItem.vue", "node_modules/vitepress/dist/client/theme-default/components/VPLocalNavOutlineDropdown.vue?vue&type=script&setup=true&lang.ts", "node_modules/vitepress/dist/client/theme-default/components/VPLocalNavOutlineDropdown.vue", "node_modules/vitepress/dist/client/theme-default/components/VPLocalNav.vue?vue&type=script&setup=true&lang.ts", "node_modules/vitepress/dist/client/theme-default/components/VPLocalNav.vue", "node_modules/vitepress/dist/client/theme-default/components/VPSidebarItem.vue?vue&type=script&setup=true&lang.ts", "node_modules/vitepress/dist/client/theme-default/components/VPSidebarItem.vue", "node_modules/vitepress/dist/client/theme-default/components/VPSidebarGroup.vue?vue&type=script&setup=true&lang.ts", "node_modules/vitepress/dist/client/theme-default/components/VPSidebarGroup.vue", "node_modules/vitepress/dist/client/theme-default/components/VPSidebar.vue?vue&type=script&setup=true&lang.ts", "node_modules/vitepress/dist/client/theme-default/components/VPSidebar.vue", "node_modules/vitepress/dist/client/theme-default/components/VPNavScreenSocialLinks.vue?vue&type=script&setup=true&lang.ts", "node_modules/vitepress/dist/client/theme-default/components/VPNavScreenSocialLinks.vue", "node_modules/vitepress/dist/client/theme-default/components/VPNavBarHamburger.vue?vue&type=script&setup=true&lang.ts", "node_modules/vitepress/dist/client/theme-default/components/VPNavBarHamburger.vue", "node_modules/vitepress/dist/client/theme-default/components/VPNavScreenTranslations.vue?vue&type=script&setup=true&lang.ts", "node_modules/vitepress/dist/client/theme-default/components/VPNavScreenTranslations.vue", "node_modules/vitepress/dist/client/theme-default/components/VPNavBarSocialLinks.vue?vue&type=script&setup=true&lang.ts", "node_modules/vitepress/dist/client/theme-default/components/VPNavBarSocialLinks.vue", "node_modules/vitepress/dist/client/theme-default/components/VPNavBarTitle.vue?vue&type=script&setup=true&lang.ts", "node_modules/vitepress/dist/client/theme-default/components/VPNavBarTitle.vue", "node_modules/vitepress/dist/client/theme-default/composables/edit-link.js", "node_modules/vitepress/dist/client/theme-default/composables/prev-next.js", "node_modules/vitepress/dist/client/theme-default/components/VPNavScreenAppearance.vue?vue&type=script&setup=true&lang.ts", "node_modules/vitepress/dist/client/theme-default/components/VPNavScreenAppearance.vue", "node_modules/vitepress/dist/client/theme-default/components/VPNavBarExtra.vue?vue&type=script&setup=true&lang.ts", "node_modules/vitepress/dist/client/theme-default/components/VPNavBarExtra.vue", "node_modules/vitepress/dist/client/theme-default/components/VPDocAsideOutline.vue?vue&type=script&setup=true&lang.ts", "node_modules/vitepress/dist/client/theme-default/components/VPDocAsideOutline.vue", "node_modules/vitepress/dist/client/theme-default/components/VPNavScreenMenuLink.vue?vue&type=script&setup=true&lang.ts", "node_modules/vitepress/dist/client/theme-default/components/VPNavScreenMenuLink.vue", "node_modules/vitepress/dist/client/theme-default/components/VPDocFooterLastUpdated.vue?vue&type=script&setup=true&lang.ts", "node_modules/vitepress/dist/client/theme-default/components/VPDocFooterLastUpdated.vue", "node_modules/vitepress/dist/client/theme-default/components/VPDocFooter.vue?vue&type=script&setup=true&lang.ts", "node_modules/vitepress/dist/client/theme-default/components/VPDocFooter.vue", "node_modules/vitepress/dist/client/theme-default/components/VPDocAsideCarbonAds.vue?vue&type=script&setup=true&lang.ts", "node_modules/vitepress/dist/client/theme-default/components/VPDocAsideCarbonAds.vue", "node_modules/vitepress/dist/client/theme-default/components/VPDocAside.vue?vue&type=script&setup=true&lang.ts", "node_modules/vitepress/dist/client/theme-default/components/VPDocAside.vue", "node_modules/vitepress/dist/client/theme-default/components/VPDoc.vue?vue&type=script&setup=true&lang.ts", "node_modules/vitepress/dist/client/theme-default/components/VPDoc.vue", "node_modules/vitepress/dist/client/theme-default/components/VPContent.vue?vue&type=script&setup=true&lang.ts", "node_modules/vitepress/dist/client/theme-default/components/VPContent.vue", "node_modules/vitepress/dist/client/theme-default/components/VPNavBarMenuGroup.vue?vue&type=script&setup=true&lang.ts", "node_modules/vitepress/dist/client/theme-default/components/VPNavBarMenuGroup.vue", "node_modules/vitepress/dist/client/theme-default/components/VPMenuLink.vue?vue&type=script&setup=true&lang.ts", "node_modules/vitepress/dist/client/theme-default/components/VPMenuLink.vue", "node_modules/vitepress/dist/client/theme-default/components/VPNavBarMenuLink.vue?vue&type=script&setup=true&lang.ts", "node_modules/vitepress/dist/client/theme-default/components/VPNavBarMenuLink.vue", "node_modules/vitepress/dist/client/theme-default/components/VPNavBarMenu.vue?vue&type=script&setup=true&lang.ts", "node_modules/vitepress/dist/client/theme-default/components/VPNavBarMenu.vue", "node_modules/vitepress/dist/client/theme-default/composables/flyout.js", "node_modules/vitepress/dist/client/theme-default/components/VPSwitch.vue", "node_modules/vitepress/dist/client/theme-default/components/VPSwitchAppearance.vue?vue&type=script&setup=true&lang.ts", "node_modules/vitepress/dist/client/theme-default/components/VPSwitchAppearance.vue", "node_modules/vitepress/dist/client/theme-default/components/VPNavBarAppearance.vue?vue&type=script&setup=true&lang.ts", "node_modules/vitepress/dist/client/theme-default/components/VPNavBarAppearance.vue", "node_modules/vitepress/dist/client/theme-default/components/VPNavScreenMenuGroupLink.vue?vue&type=script&setup=true&lang.ts", "node_modules/vitepress/dist/client/theme-default/components/VPNavScreenMenuGroupLink.vue", "node_modules/vitepress/dist/client/theme-default/components/VPNavScreenMenuGroupSection.vue?vue&type=script&setup=true&lang.ts", "node_modules/vitepress/dist/client/theme-default/components/VPNavScreenMenuGroupSection.vue", "node_modules/vitepress/dist/client/theme-default/components/VPNavScreenMenuGroup.vue?vue&type=script&setup=true&lang.ts", "node_modules/vitepress/dist/client/theme-default/components/VPNavScreenMenuGroup.vue", "node_modules/vitepress/dist/client/theme-default/components/VPNavScreenMenu.vue?vue&type=script&setup=true&lang.ts", "node_modules/vitepress/dist/client/theme-default/components/VPNavScreenMenu.vue", "node_modules/vitepress/dist/client/theme-default/components/VPNavScreen.vue?vue&type=script&setup=true&lang.ts", "node_modules/vitepress/dist/client/theme-default/components/VPNavScreen.vue", "node_modules/vitepress/dist/client/theme-default/components/VPMenuGroup.vue?vue&type=script&setup=true&lang.ts", "node_modules/vitepress/dist/client/theme-default/components/VPMenuGroup.vue", "node_modules/vitepress/dist/client/theme-default/components/VPMenu.vue?vue&type=script&setup=true&lang.ts", "node_modules/vitepress/dist/client/theme-default/components/VPMenu.vue", "node_modules/vitepress/dist/client/theme-default/components/VPFlyout.vue?vue&type=script&setup=true&lang.ts", "node_modules/vitepress/dist/client/theme-default/components/VPFlyout.vue", "node_modules/vitepress/dist/client/theme-default/components/VPNavBarTranslations.vue?vue&type=script&setup=true&lang.ts", "node_modules/vitepress/dist/client/theme-default/components/VPNavBarTranslations.vue", "node_modules/vitepress/dist/client/theme-default/components/VPNavBar.vue?vue&type=script&setup=true&lang.ts", "node_modules/vitepress/dist/client/theme-default/components/VPNavBar.vue", "node_modules/vitepress/dist/client/theme-default/components/VPNav.vue?vue&type=script&setup=true&lang.ts", "node_modules/vitepress/dist/client/theme-default/components/VPNav.vue", "node_modules/vitepress/dist/client/theme-default/Layout.vue?vue&type=script&setup=true&lang.ts", "node_modules/vitepress/dist/client/theme-default/Layout.vue" and "node_modules/vitepress/dist/client/app/index.js".

Validations

Metadata

Metadata

Assignees

No one assigned

    Labels

    buildRelated to the build systemupstreamRelated to the dependencies

    Type

    Projects

    No projects

    Milestone

    No milestone

    Relationships

    None yet

    Development

    No branches or pull requests

    Issue actions