基于vue 动态加载图片src的解决方法


Posted in Javascript onFebruary 05, 2018

好久没更博了,最近也不知道在忙啥,反正就是感觉挺忙的,在群里看到陆陆续续有刚入vue小伙伴问vue动态加载图片总是404的状况,这篇就简单的说明为什么会出现以及解决办法有哪些。

首先先说明下vue-cli的assets和static的两个文件的区别,因为这对你理解后面的解决办法会有所帮助

assets:在项目编译的过程中会被webpack处理解析为模块依赖,只支持相对路径的形式,如< img src=”./logo.png”>和background:url(./logo.png),”./logo.png”是相对资源路径,将有webpack解析为模块依赖

static:在这个目录下文件不会被webpack处理,简单就是说存放第三方文件的地方,不会被webpack解析。他会直接被复制到最终的打包目录(默认是dist/static)下。必须使用绝对路径引用这些文件,这是通过config.js文件中的build.assetsPublic和build.assertsSubDirectory链接来确定的。任何放在static/中文件需要以绝对路径的形式引用:/static[filename]

根据webpack的特性,总的来说就是static放不会变动的,第三档的文件,asserts放可能会变动的文件

问题来了,用js动态加载assets或者本文件的图片出现404的状态码

代码实例

<li v-for="(item,index) in images" :key="index">
<img :src="item.src"></li>
//js部分
data(){
 return {
 images:[{src:'./1.png'},{./2.png}]
 }
}

跑起来发现图片不显示,错误码为404,

原因:在webpack中会将图片图片来当做模块来用,因为是动态加载的,所以url-loader将无法解析图片地址,然后npm run dev 或者npm run build之后导致路径没有被加工【被webpack解析到的路径都会被解析为/static/img/[filename].png,完整地址为localhost:8080/static/img/[filename].png】

解决办法:

将图片作为模块加载进去,比如images:[{src:require(‘./1.png')},{src:require(‘./2.png')}]这样webpack就能将其解析。

②将图片放到static目录下,但必须写成绝对路径如images:[{src:”/static/1.png”},{src:”/static/2.png”}]这样图片也会显示出来,当然你也可以通过在webpack.base.config.js定义来缩短路径的书写长度。

当然你说当本地图片太多时,这样写岂不是很麻烦,那么其实我们是一这样简化操作的。

第一步:在static里面新建一个json文件夹

基于vue 动态加载图片src的解决方法

第二部:填写json文件,如图

基于vue 动态加载图片src的解决方法

第三部:将json引入响应的vue文件中,解析引用就行了

基于vue 动态加载图片src的解决方法

如有疑问,欢迎进行讨论。

以上这篇基于vue 动态加载图片src的解决方法就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
关于__defineGetter__ 和__defineSetter__的说明
May 12 Javascript
JavaScript与C# Windows应用程序交互方法
Jun 29 Javascript
原生JS实现加入收藏夹的代码
Oct 24 Javascript
JavaScript获取网页中第一个图片id的方法
Apr 03 Javascript
APP中javascript+css3实现下拉刷新效果
Jan 27 Javascript
jQuery增加与删除table列的方法
Mar 01 Javascript
基于jquery实现轮播特效
Apr 22 Javascript
JQuery动态添加Select的Option元素实现方法
Aug 29 Javascript
图片懒加载插件实例分享(含解析)
Jan 09 Javascript
pace.js和NProgress.js两个加载进度插件的一点小总结
Jan 31 Javascript
解决Vue-cli npm run build生产环境打包,本地不能打开的问题
Sep 20 Javascript
VUE引入第三方js包及调用方法讲解
Mar 01 Javascript
vue2.0 datepicker使用方法
Feb 04 #Javascript
js数组常用最重要的方法
Feb 04 #Javascript
jQuery Dom元素操作技巧
Feb 04 #jQuery
Vue的事件响应式进度条组件实例详解
Feb 04 #Javascript
JS实现不用中间变量temp 实现两个变量值得交换方法
Feb 04 #Javascript
Vue的土著指令和自定义指令实例详解
Feb 04 #Javascript
彻底理解js面向对象之继承
Feb 04 #Javascript
You might like
linux命令之调试工具strace的深入分析
2013/06/03 PHP
php的hash算法介绍
2014/02/13 PHP
phpMyAdmin无法登陆的解决方法
2017/04/27 PHP
Laravel向公共模板赋值方法总结
2019/06/25 PHP
javascript字典探测用户名工具
2006/10/05 Javascript
js单向链表的具体实现实例
2013/06/21 Javascript
html文档中的location对象属性理解及常见的用法
2014/08/13 Javascript
分享两个手机访问pc网站自动跳转手机端网站代码
2020/12/24 Javascript
js实现图片漂浮效果的方法
2015/03/02 Javascript
快速学习jQuery插件 Form表单插件使用方法
2015/12/01 Javascript
JS中setTimeout和setInterval的最大延时值详解
2017/02/13 Javascript
JavaScript实现替换字符串中最后一个字符的方法
2017/03/07 Javascript
微信小程序页面开发注意事项整理
2017/05/18 Javascript
使用Node.js实现RESTful API的示例
2017/08/01 Javascript
ES6学习教程之块级作用域详解
2017/10/09 Javascript
vue2.0s中eventBus实现兄弟组件通信的示例代码
2017/10/25 Javascript
Angularjs实现数组随机排序的方法
2018/10/02 Javascript
JavaScript this在函数中的指向及实例详解
2019/10/14 Javascript
微信小程序登陆注册功能的实现代码
2019/12/10 Javascript
js实现3D旋转相册
2020/08/02 Javascript
[02:47]DOTA2亚洲邀请赛 HR战队出场宣传片
2015/02/07 DOTA
Python list操作用法总结
2015/11/10 Python
Python实现的rsa加密算法详解
2018/01/24 Python
深入了解Python在HDA中的应用
2019/09/05 Python
tensorflow自定义激活函数实例
2020/02/04 Python
在keras 中获取张量 tensor 的维度大小实例
2020/06/10 Python
解决redis与Python交互取出来的是bytes类型的问题
2020/07/16 Python
德国香水、化妆品和护理产品网上商店:Parfumdreams
2018/09/26 全球购物
New Balance比利时官方网站:购买鞋子和服装
2021/01/15 全球购物
工程部经理岗位职责
2013/12/08 职场文书
《蚂蚁和蝈蝈》教学反思
2014/02/24 职场文书
春风行动实施方案
2014/03/28 职场文书
2019年思想汇报
2019/06/20 职场文书
ES6 解构赋值的原理及运用
2021/05/25 Javascript
SQL 尚未定义空闲 CPU 条件 - OnIdle 作业计划将不起任何作用
2021/06/30 SQL Server
MySQL8.0的WITH查询详情
2021/08/30 MySQL