vue3 vite动态拼接图片路径

javascript 复制代码
// 1. 在文件顶部预先加载 assets 目录下所有 jpg 和 png 图片的映射表
// eager: true 表示同步加载,直接获取模块对象
const imageModules = import.meta.glob('../assets/**/*.{jpg,jpeg,png,JPG,PNG}', { eager: true });

/**
 * 获取通用静态资源(保持你原有的逻辑,因为路径结构是固定的)
 */
export function getAssetsFile(url) {
  return new URL(`../assets/${url}`, import.meta.url).href;
}

/**
 * 根据文件名和分类动态获取草药图片
 */
export function getHerbImage(filename, category) {
  if (!filename) return '';
  
  // 2. 拼接出相对于当前文件的预期路径
  const dir = category === '矿物药' ? 'images/minerals/' : 'images/plants/';
  const expectedPath = `../assets/${dir}${filename}`;
  
  // 3. 从预加载的映射表中获取图片 URL
  if (imageModules[expectedPath]) {
    return imageModules[expectedPath].default;
  }
  
  // 4. 找不到图片时的兜底处理(方便排查问题)
  console.warn(`[getHerbImage] 图片未找到: ${expectedPath}`);
  return ''; 
}

/**
 * 批量获取草药图片(处理逗号分隔的字符串)
 */
export function getHerbImages(filenames, category) {
  if (!filenames) return [];
  return filenames
    .split(',')
    .map((f) => f.trim())
    .filter(Boolean)
    .map((f) => getHerbImage(f, category));
}

全局映射表:import.meta.glob('.../assets/**/*.{jpg,jpeg,png,JPG,PNG}', { eager: true }) 会在 Vite 构建时扫描该目录,生成一个包含所有匹配文件路径的对象。

路径匹配:expectedPath 必须与 glob 生成的 key 完全一致。由于 index.js 在 src/utils/ 下,所以相对路径必须以 .../assets/ 开头。

获取真实 URL:因为使用了 { eager: true },所以图片的真实 URL 存储在 imageModulesexpectedPath.default 中。

容错处理:增加了 console.warn,如果以后不小心传错了文件名,控制台会直接告诉你哪个路径没匹配上,避免再次出现 undefined 或空白图片。

相关推荐
山河木马10 小时前
矩阵专题3-怎么创建投影矩阵(uProjectionMatrix)
javascript·webgl·计算机图形学
泯泷12 小时前
第 2 篇:设计第一套字节码:Opcode、Instruction 与 Constant Pool
前端·javascript·安全
泯泷12 小时前
第 1 篇:从 1 + 2 开始:亲手写出第一台 JSVM
前端·javascript·安全
朦胧之13 小时前
页面白屏卡住排查方法
前端·javascript
犇驫聊AI13 小时前
Chrome DevTools MCP + Claude Code 自定义skills生成接口代码生成器
前端·javascript
kyriewen14 小时前
别再这样写 async/await 了:我在 Code Review 中见过最多的 8 个错误
前端·javascript·面试
用户2986985301418 小时前
在 React 中使用 JavaScript 将 Excel 转换为 SVG
前端·javascript·react.js
labixiong19 小时前
手写Promise--微任务、静态方法、async/await 全搞懂(三)
前端·javascript
铁皮饭盒20 小时前
3行代码搞定页面截图,Bun.WebView真的简单
javascript
kyriewen1 天前
我手写了一个 EventEmitter,面试官追问了 6 个问题——第 4 个我没答上来
前端·javascript·面试