当前位置: 首页 > ai >正文

在 Vue + Vite 项目中,直接使用相对路径或绝对路径引用本地图片资源时,图片无法正确显示。

Vue 项目中静态资源引用问题

1.问题描述

在 Vue + Vite 项目中,直接使用相对路径或绝对路径引用本地图片资源时,图片无法正确显示。

错误示例

```javascript

// 错误方式1:使用相对路径

const products = [

  {

    name: 'iPhone 14 Pro',

    image: '../assets/iphone.jpg'  // ❌ 相对路径可能找不到正确位置

  }

]

// 错误方式2:使用项目绝对路径

const products = [

  {

    name: 'iPhone 14 Pro',

    image: '/shopping-mall/src/assets/iphone.jpg'  // ❌ 生产环境中路径会失效

  }

]

```

这些路径的问题:

1. 相对路径 `../assets/` 在运行时可能找不到正确位置

2. 绝对路径 `/shopping-mall/src/assets/` 在打包后会失效

3. 不会被 Vite 正确处理和优化

4. 生产环境中可能出现 404 错误

2. 解决方案

在 Vue + Vite 项目中,应该使用 `import` 方式导入静态资源。

 正确示例

```javascript

// 1. 在文件顶部导入图片

import iphone14Pro from '../assets/Apple iPhone 14 Pro.jpg'

import airJordan from '../assets/Nike Air Jordan 1.jpg'

// 2. 在数据中使用导入的变量

const products = [

  {

    name: 'iPhone 14 Pro',

    image: iphone14Pro  // ✅ 使用导入的变量

  },

  {

    name: 'Nike Air Jordan 1',

    image: airJordan    // ✅ 使用导入的变量

  }

]

```

3. 优势

使用 import 导入静态资源的优势:

1. **资源处理**:Vite 会自动处理图片资源

2. **路径解析**:确保在开发和生产环境中都能正确加载

3. **自动优化**:

   - 图片会被正确打包和优化

   - 支持 tree-shaking(未使用的图片不会被打包)

   - 生产环境中自动添加 hash,有利于缓存

4. **类型安全**:可以获得 IDE 的路径补全和类型检查

4. 注意事项

1. 确保图片文件放在正确的目录(通常是 `src/assets`)

2. 图片文件名要与导入名称完全匹配(包括大小写和空格)

3. 使用支持的图片格式(.jpg, .png, .webp 等)

4. 如果需要动态路径,可以使用 Vite 的 `new URL()` 语法或 `@/assets` 别名

http://www.xdnf.cn/news/9394.html

相关文章:

  • Claude 4对比Claude 3.7全面评测:2025最新AI模型实测对比
  • 山东大学软件学院创新项目实训开发日志——第十三周
  • xilinx 7系列底层可配置逻辑块CLB中的LUT、FF等资源
  • IT编程学习资料大全​​​​​​​​
  • 嵌入式学习之系统编程(六)线程
  • 打破边界 智启新篇 新一代质检LIMS系统的演进蓝图
  • QGis实现geoserver上的样式展示(方便样式编辑)
  • ShardingSphere-读写分离
  • leetcode0611. 有效三角形的个数-medium
  • ROS2学习(14)------ ROS2Launch 多节点启动与配置脚本
  • 基于stm32的 永磁同步电机二电平驱动控制系统设计
  • OpenKylin文件管理器界面层级切换问题
  • 多相电机驱动控制学习(1)——基于双dq坐标系的六相/双三相PMSM驱动控制
  • ABC 377
  • 互联网医疗问诊APP原型设计:12个实战案例解析
  • Workflow
  • 如何合理选择智能外呼机器人:多维评估
  • SAP-ABAP:SAP的DMS根据物料号获取附件详解
  • 网络通信的基石:深入理解帧与报文
  • [BUG记录]0X10 会话切换服务响应NRC 0x10
  • <<运算符重载 和 c_str() 的区别和联系
  • TF 卡和 NM 卡有何区别?
  • openinstall支持豆瓣广告监测,赋能品牌深挖社交流量
  • Baklib知识中台体系构建与应用解析
  • 比较转录组-油料作物-文献精读133
  • Jenkins实践(10):pipeline构建历史展示包名和各阶段间传递参数
  • 【深度学习新浪潮】智能眼镜关键技术拆解(简要版)
  • 什么是 BOM 表,如何通过 BOM 表做好生产管理
  • git 删除某次commit并 推送到 origin
  • 安装 LCMS-8060 三重四级杆配件的详细步骤和要点