在vue3+vite项目下按需引入vant报错Failed to resolve import解决方案

    • 问题描述
    • 原因分析
    • 解决方案

问题描述

近日尝试使用vite+vue3+vant开发项目过程中,参考vant官网开发指南->快速上手->引入组件

按照上述配置好后,运行vite环境报错:Failed to resolve import

原因分析

根据报错信息,发现是vant的样式引入路径不对。
程序解析为:项目路径/node_modules/vant/lib/vant/es/组件/style
实际应该是:项目路径/node_modules/vant/lib/ vant/es/组件/style
多了一个vant/lib路径。

解决方案

vite.config.js文件中解析至正确路径。
vant官网的代码如下:

在styleImport内添加代码块:

libs: [        {          libraryName: 'vant',          esModule: true,          resolveStyle: name => `../es/${name}/style`        }      ]

完整代码如下:

import vue from '@vitejs/plugin-vue';import styleImport, { VantResolve } from 'vite-plugin-style-import';export default {  plugins: [    vue(),    styleImport({      resolves: [VantResolve()],      libs: [        {          libraryName: 'vant',          esModule: true,          resolveStyle: name => `../es/${name}/style`        }      ]    }),  ],};

修改后,重新运行vite,问题解决。