解决vue项目在本地正常显示,打包后图片无法正常显示的问题

在项目中使用图片,图片一般保存在static,或者assets目录的img里,而获取图片可以使用绝对路径或者相对路径,虽然在本地使用哪种方式没有影响,但由于vue的打包问题,如果采用绝对路径,打包至线上会导致无法正常显示图片,如下图:

 ,当然这不是我们想要的结果,所以我们要通过将绝对路径改为相对路径的方式来解决这个问题。

一般来说,相对路径有以下几种方式:

1. src="../../../../assets/img/upload.svg" 。其中../的次数由几级目录决定

2.:src="require('@/assets/img/result-complete.svg')"

我当时是采用这两种方式解决了大部分的的图片显示问题,但在树形控件那里,为了实现点击选中才显示对应的图片效果,el-tree教程默认是全部节点都显示的,效果见下图

官方效果:

我实现的效果:

但实现这个功能我用的是setTimeout和prepend,然后问题出现了,以上两种相对路径的方式都没法解决图片显示的问题,而且每次测试都要重新打包,过程相当漫长,终于在大佬的帮助下,找到了解决方法

使用下面这种方式就可以解决问题了:

有没有帮到您呢,欢迎留言,喜欢记得点赞哦!

  • 2
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值