vue中使用相对路径图片不显示

因为webpack问题,webpack打包会将静态资源放在一个webpack创建的Img文件夹中,并且图片名字还会被更改

我的文件目录是没有Img文件夹的,且图片名字没有那串乱字符

  1. 路径问题:

    • Vue 项目通常会将资源文件放在 src/assets 目录下,并通过 webpack 来处理资源路径。
    • 在你的代码中,第一张图片 ./banner1.jpg 的路径是相对的,而第二张图片的路径是 ./html/hanjiang/hanjiang/src/assets/banner2.jpg,这个路径看起来比较复杂,可能不符合项目的文件结构或配置。

    解决方法:

    • 确保图片 banner2.jpg 确实存在于指定路径中。

    • 更改第二张图片的路径为相对 src/assets 的路径。例如,如果 banner2.jpg 存在于 src/assets 目录下,可以使用 require 来引入:

      复制代码

      javascript
      bannerImg: [require('@/assets/banner1.jpg'), require('@/assets/banner2.jpg')] 使用 @/assets 是指从 src/assets 开始的路径。

  2. 资源处理配置:

    • Vue CLI 默认配置下,静态资源的路径通常需要使用 requireimport 语句来正确处理。直接使用字符串路径可能导致路径解析错误。

    解决方法:

    • 使用 require 语法确保图片路径正确:

      复制代码

      javascript
      data: function () { return { bannerImg: [require('@/assets/banner1.jpg'), require('@/assets/banner2.jpg')] } } 这样可以确保 webpack 能够正确处理图片路径。

  3. 图片加载问题:

    • 如果图片文件存在,但路径不正确,可能会导致图片无法加载。确保路径是正确的,并且图片文件确实在项目的 src/assets 目录或相对位置中。
  4. 缓存问题:

    • 有时浏览器缓存可能会导致图片无法正确加载。可以尝试清除浏览器缓存或在路径后添加查询字符串来强制刷新:

      复制代码

      <img :src="bannerImg[0] + '?v=1'" alt="" style="width: 1200px;">

相关推荐
Din27 分钟前
主动取消的防抖
前端·javascript·typescript
百度地图汽车版37 分钟前
【AI地图 Tech说】第九期:让智能体拥有记忆——打造千人千面的小度想想
前端·后端
臣妾没空42 分钟前
Elpis 全栈框架:从构建到发布的完整实践总结
前端·后端
H5开发新纪元42 分钟前
Nginx 部署 Vue3 项目完整指南
前端·javascript·面试
决斗小饼干44 分钟前
跨语言移植手记:把 TypeScript 的 Codex SDK 请进 .NET 世界
前端·javascript·typescript
小码哥_常1 小时前
Android Intent.setAction失效报错排查与修复全方案
前端
进击的尘埃1 小时前
Vitest 浏览器模式:别再用 jsdom 骗自己了
javascript
bluceli1 小时前
JavaScript模块化深度解析:从CommonJS到ES Modules的演进之路
前端·javascript
前端人类学1 小时前
前端输入框禁用:disabled、readonly 与.prop (‘disabled‘, true) 完全解析
前端·javascript
优秀稳妥的JiaJi1 小时前
分享一篇后台管理系统的通用skills
前端·vue.js·前端框架