angular 指定components的路径_vue之 动态定义图片路径

1952161e98abae020b3dca1bd588271d.png 阅读本文约需要5分钟

大家好,我是你们的导师,经常看我朋友圈的同学应该知道,我每天会在微信上给大家免费提供以下服务!

1、长期为你提供最优质的学习资源!

2、给你解决技术问题!

3、每天在朋友圈里分享优质的技术文章!

4、每周1、3、5送纸质书籍免费送给大家,每年至少送书800本书!

5、为大家推荐靠谱的就业单位!

请注意!我上面说的5点全部都是免费的!全网你应该找不到第二家吧!

当然,大家在我私人微信上问我问题,仅限回答web前端、java相关的。

---------------------------

好了,接下来开始今天的技术分享!上次老师跟大家分享了CSS之 响应式布局的知识,今天跟大家分享下vue之 动态定义图片路径的知识。

0 前言 最近在使用vue动态设置图片路径的时候遇到了一些问题,特此整理。 我想实现的效果:点击图片,弹出系统图片选择框,选择图片后替换原图片。 App.vue中:
<input type="file" id="avatar" @change="chooseFile($event)" accept="image/*" style="display: none" ><label for="avatar"><img :src="../assets/user_1.png" alt="图片">label>
结果: ec7e793c32a6ebea361d6331c587ee4f.png 默认图片加载成功,点击该图片可以弹出图片选择框。 本着组件抽象的原则,我想把上述代码抽象成组件,并且希望默认的图片url可以在父组件指定,于是,我这样写: App.vue:
<template><ItemShow-imageChoose id="userPicture" imageSrc="../assets/user.png">ItemShow-imageChoose>template><script>import ItemShow_imageChoose from "./components/ItemShow-imageChoose"export default {name:'App',components: {"ItemShow-imageChoose":ItemShow_imageChoose      }    }
./components/ItemShow-imageChoose.vue:
<template><div><input type="file" :id="id" @change="chooseFile($event)" accept="image/*" style="display: none" ><label :for="id"><img :src="imageSrc" alt="图片">label>div>template><script>export default{name:'ItemShow_imageChoose',props:{"id":[String],"imageSrc":[String]          },methods:{              chooseFile(e){//                  this.$emit('choose',e.target.files)              }          }      }script>
结果: e68b474cbee7197b9a038248cbe43267.png 默认图片没有加载出来。 开始一步步找错.... 首先,把图片的src移至子组件的data中,看图片是否能加载出来: ./components/ItemShow-imageChoose.vue:
<template><div><input type="file" :id="id" @change="chooseFile($event)" accept="image/*" style="display: none" ><label :for="id"><img :src="src" alt="图片" />label>div>template><script>export default{name:'ItemShow_imageChoose',props:{"id":[String],"imageSrc":[String]        },        data(){return {src:'../assets/user.png'    //重点看这里          }        },methods:{            chooseFile(e){//                this.$emit('choose',e.target.files)            }        }    }script>
结果: e68b474cbee7197b9a038248cbe43267.png 本来以为这样写肯定是对的,结果竟然不对,但是这个结果也说明:问题不是出在父子组件的参数传递上。 于是开始查资料.... 看了一些文章和问答,也大致理解了出错的原因(参考文章见附录),是图片路径的问题。 如果图片地址是直接写死在html或者css里的,webpack会帮你处理这个图片最终的地址(要用到url-loader),例如: 初始:

webpack编译后会变成:

实测:

打包成绝对路径:

4fd71a980c24d633aea6141fd5197a58.png

打包成base64字符串:

936dac9ab421f05e40b97b47aad62b20.png

项目目录:

d7ac8d8536e9f13e6af036d66eda8e26.png

以上就是webpack打包的两种方式,我们重点看第一种。第一种方式,图片是以绝对路径(以/开头的路径就是绝对路径,/指根目录,根目录在本地就是指磁盘,在github上就是指仓库的根目录,在网站上就是指服务器的根目录)进行查找,图片的目录为/static/img,但是我们查看上图项目目录,发现static目录下并没有img目录,也没有图片,那么这里的路径是怎么来的呢? 运行npm run build,再看一下项目目录: 5ede77298875c8dc53dc863fc0fd90de.png 我们在dist目录下面找到了该图片。由此知道, webpack打包后,会将静态资源文件放在dist/static/img下,我们的网站实际上以dist目录作为根目录,并由此加载该目录下的index.html所需的css、js、img等。 现在我们使用Vue.js来动态定义图片路径:
<template><div><img :src="src" alt="图片" />div>template><script>export default{        data(){return {src:`../assets/user.png`          }        }    }script>
结果: c657a1f6908bd21286dae719999c3fe2.png dist目录为根目录,index.html的路径为“./index.html”,那“../assets/user.png”即为与dist目录平级的assets目录下面的user.png,我们发现该目录不存在,图片自然加载失败。 当Vue.js来动态定义图片路径的时候,url-loader是无法探测到图片路径的。 我们build后发现,图片根本不会打包输出到dist目录(webpack是按需打包的): 0fb0939b45a88e32bee412983ec429bc.png 由上图可知,dist目录下无图片文件或文件夹。 如何解决? 我整理并测试了以下三种解决办法: 1、绝对路径访问 把图片放到静态资源目录static目录下(build 会将static目录中的文件或者文件夹按照原本的结构放在dist目录下),并用/static绝对路径访问:
<template><div><img :src="src" alt="图片" />div>template><script>export default{        data(){return {src:`/static/img/user.png`          }        }    }script>
结果: 615be51cee6a7a2d30fea0e0570a6cf5.png 2、使用require 如果想在不调整目录结构的情况下读取图片,还可以使用require:

data(){return { src:require('../assets/user.png') //重点看这里 }}

a5ad5291dcb4b98bbadacd85940b0e57.png

该结果与上面说的webpack打包的第一种方式结果相同。 缺点:由于CommonJS只允许使用字符串字面量,所以不利于组件化,灵活性较差。 3、使用import 也可以用import引入图片路径:

import userPath from '../assets/user.png'export default{ data(){return {src:userPath } } }

结果:

c5a23d6df5037ef351f51dd52457a889.png

该结果与上面说的webpack打包的第一种方式结果相同。 就先整理到这里。多花些时间踩踩坑也是很好的,学到了就是赚到了。由于个人水平有限,错误之处,烦请指正! 附完整代码 ./components/ItemShow-imageChoose.vue:
<template><div><input type="file" :id="id" @change="chooseFile($event)" accept="image/*" style="display: none" ><label :for="id"><img :src="'/static/img/'+imageSrc" alt="图片" />label>div>template><script>export default{name:'ItemShow_imageChoose',props:{"id":[String],"imageSrc":[String]        },methods:{            chooseFile(e){var currentImg=e.target.nextElementSibling.childNodes[0]                currentImg.setAttribute('src',window.URL.createObjectURL(e.target.files[0]))                currentImg.onload=function () {window.URL.revokeObjectURL(this.src)                }            }        }    }script>
参考文献:https://www.jianshu.com/p/fab484498e4e
今天就分享这么多, 于vue之 动态定义图片路径 学会了多少欢迎在留言区评论,对于有价值的留言,我们都会一一回复的。如果觉得文章对你有一丢丢帮助,请点右下角【在看】,让更多人看到该文章。 03980bd41b6be4e564f688009ec3a045.png

ec5c478aeab3898f7d24f0994b5d9324.png

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值