webpack打包vue项目后,一些文件图片路径找不到的问题解决办法
2017-09-23 15:40
1121 查看
最近写了一个百度地图的项目,要求底部有一个导航栏。具体如下图:
首先,拿到了底部导航栏的所有图标图片,图片都有两种。灰色的代表未选中,选中的用带样色的图片替换。
先看一下,组件中 html结构:通过vue提供的v-for方法,进行遍历显示footNav这个数组。数组里边存放着{title:"银行",url:" ",url1:" "},将图片的 src与isSelect进行绑定,并进行判断,如果等于当前的title时即为选中当前的导航,显示选中时的图片url1。
在vue data () 中定义一个数组,里边存放每一个导航的标题,如‘银行’,未选中时显示的图片url,选中时的图片url1。isSelect表示当前选中的,默认选中银行。
在methods方法中,写上html中调用的事件。通过html结构层那里的点击事件selectMapNav(item.title)传过来的title赋值给isSelect即可实现导航栏的点击状态的变化。
因为,我这里的url是通过绑定数据层的url里边字符串实现。这就会导致最后通过webpack打包后,这个路径还是这个字符串里边的路径不会改变。
所以,出现了找不这张图片的现象。
解决办法:因为通过webpack打包后就一个static文件夹。所以通过webpack打包前把上面的url路径改为下面的路径:
这样就不会出现,webpack打包后的文件,路径找不到的问题。
首先,拿到了底部导航栏的所有图标图片,图片都有两种。灰色的代表未选中,选中的用带样色的图片替换。
先看一下,组件中 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打包后的文件,路径找不到的问题。
相关文章推荐
- 解决vue项目打包后提示图片文件路径错误的问题
- vue-cli中解决css引用图片打包后找不到文件资源的问题
- 详谈vue+webpack解决css引用图片打包后找不到资源文件的问题
- 解决vue-cli项目webpack打包后iconfont文件路径的问题
- vue+webpack解决css引用图片打包后找不到资源文件的问题
- 解决vue打包css文件中背景图片的路径问题
- vue-cli项目webpack打包后iconfont文件路径问题解决
- SpringBoot项目打包后,找不到文件路径问题,处理方法
- 在JAVA WEB项目中,JSP中的图片无法显示,绝对路径和相对路径问题的解决办法。
- vue项目打包后资源相对引用路径的和背景图片路径问题
- vue-cli项目打包后图片路径问题
- vue-cli webpack模板项目搭建及打包时路径问题的解决方法
- Java项目打包成Jar文件后图片不显示的问题解决
- 解决Vue打包后背景图片路径错误问题
- vue打包css文件中背景图片的路径问题
- 路径不对 导致FileNotFoundError: [WinError 2] 系统找不到指定的文件, 问题解决办法
- 解决Vue打包之后文件路径出错的问题
- 读取web项目properties文件路径 解决tomcat服务器找不到properties路径问题
- vue 项目打包时样式及背景图片路径找不到
- 解决Vue打包后背景图片路径错误问题