webpack打包vue项目后,一些文件图片路径找不到的问题解决办法(数据中存在图片路径解决办法)

2 篇文章 0 订阅

webpack打包vue项目后,一些文件图片路径找不到的问题解决办法

最近写了一个百度地图的项目,要求底部有一个导航栏。具体如下图:


首先,拿到了底部导航栏的所有图标图片,图片都有两种。灰色的代表未选中,选中的用带样色的图片替换。


先看一下,组件中 html结构:通过vue提供的v-for方法,进行遍历显示footNav这个数组。数组里边存放着{title:"银行",url:" ",url1:" "},将图片的 src与isSelect进行绑定,并进行判断,如果等于当前的title时即为选中当前的导航,显示选中时的图片url1。

<div class="footer">
  <ul>
    <li v-for="item in footNav" @click="selectMapNav(item.title)">
      <img :src="isSelect === item.title ? item.url1 : item.url" alt="">
      <p>{{item.title}}</p>
    </li>
  </ul>
</div>

在vue data () 中定义一个数组,里边存放每一个导航的标题,如‘银行’,未选中时显示的图片url,选中时的图片url1。isSelect表示当前选中的,默认选中银行。

isSelect: '银行',
footNav: [{title: '银行', url: '../../../static/baiduMap/23@2x.png', url1: '../../../static/baiduMap/22@2x.png'},
  {title: '公交 ', url: '../../../static/baiduMap/11@2x.png', url1: '../../../static/baiduMap/10@2x.png'},
  {title: '地铁 ', url: '../../../static/baiduMap/13@2x.png', url1: '../../../static/baiduMap/12@2x.png'},
  {title: '教育 ', url: '../../../static/baiduMap/15@2x.png', url1: '../../../static/baiduMap/14@2x.png'},
  {title: '医院 ', url: '../../../static/baiduMap/17@2x.png', url1: '../../../static/baiduMap/16@2x.png'},
  {title: '休闲 ', url: '../../../static/baiduMap/19@2x.png', url1: '../../../static/baiduMap/18@2x.png'},
  {title: '购物 ', url: '../../../static/baiduMap/21@2x.png', url1: '../../../static/baiduMap/20@2x.png'}
]

在methods方法中,写上html中调用的事件。通过html结构层那里的点击事件selectMapNav(item.title)传过来的title赋值给isSelect即可实现导航栏的点击状态的变化。

selectMapNav (title) {
  this.isSelect = title }

因为,我这里的url是通过绑定数据层的url里边字符串实现。这就会导致最后通过webpack打包后,这个路径还是这个字符串里边的路径不会改变。

所以,出现了找不这张图片的现象。

解决办法:因为通过webpack打包后就一个static文件夹。所以通过webpack打包前把上面的url路径改为下面的路径:

footNav: [{title: '银行', url: './static/baiduMap/23@2x.png', url1: './static/baiduMap/22@2x.png'},
  {title: '公交 ', url: './static/baiduMap/11@2x.png', url1: './static/baiduMap/10@2x.png'},
  {title: '地铁 ', url: './static/baiduMap/13@2x.png', url1: './static/baiduMap/12@2x.png'},
  {title: '教育 ', url: './static/baiduMap/15@2x.png', url1: './static/baiduMap/14@2x.png'},
  {title: '医院 ', url: './static/baiduMap/17@2x.png', url1: './static/baiduMap/16@2x.png'},
  {title: '休闲 ', url: './static/baiduMap/19@2x.png', url1: './static/baiduMap/18@2x.png'},
  {title: '购物 ', url: './static/baiduMap/21@2x.png', url1: './static/baiduMap/20@2x.png'}
]
这样就不会出现,webpack打包后的文件,路径找不到的问题。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值