vue render函数动态加载img的src路径操作


Posted in Javascript onOctober 26, 2020

分享一下我去如何解决vue render 中 如何正确配置img的src 路径?

一、我的项目中有俩层组件,

第一层父组件,第二层是render函数封装的组件,父组件调用render函数组件

二、render函数中需要创建<img>标签,img中的src是父组件传进来的;

src正确传进来,图片却不不显示。

三、解决办法:

首先在父组件中将图片import进来,

import empty from "./img/empty.png";

在父组件的data中声明一个变量,将empty图片引入进来

empty: empty,

父组件把图片传给子组件,子组件为

<index-grid :empty="empty"></index-grid>

子组件在props中接收empty

props: {
  empty: {
   type: String
  }
 },

子组件可以直接使用src

img.push(
    h("img", {
     style: {
      verticalAlign: "middle"
     },
     attrs: {
      src: empty
     }
    })
   );

补充知识:VUE 为img元素动态添加src及注意事项

在vue项目中,通常需要通过v-for 渲染多个img元素,当我们想给每个img元素添加他们各自的src时,需要用到vue src动态绑定

例如下面:

<img :src="typeIcon(tt.questionType)" alt="加载失败">

这里的tt 就是渲染的内容,每个img的src需要根据tt的questionType去判断

我们首先为这个判断设置一个函数,并把它绑定到img .

typeIcon:function(kind){
      switch (kind){
      case 1 : return require("../../assets/images/single_choice.png" )
      break;
      case 2 : return require( "../../assets/images/multi_choice.png" )   
      break;
      case 3 : return  require( "../../assets/images/matrix_single.png" )        
      break;
      case 4 : return  require( "../../assets/images/matrix_multi.png") 
      break;
      case 5 :return  require("../../assets/images/blank.png" )
      break;
      default: return   require( "../../assets/images/shortAnswer.png" )
    }
  },

这里我们用一个switch 语句,判断每个img对应的src 。

这里需要注意的是:

返回src时,需要在src字符串前面加上require

最后,用 :src 绑定typeIcon

<img :src="typeIcon(tt.questionType)" alt="加载失败">

以上这篇vue render函数动态加载img的src路径操作就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
JavaScript中常见陷阱小结
Apr 27 Javascript
js购物车实现思路及代码(个人感觉不错)
Dec 23 Javascript
JavaScript学习笔记之JS事件对象
Jan 22 Javascript
JS获得图片alt信息的方法
Apr 01 Javascript
jQuery增加自定义函数的方法
Jul 18 Javascript
js原生之焦点图转换加定时器实例
Dec 12 Javascript
vue使用vue-cli快速创建工程
Jul 28 Javascript
vue引用js文件的多种方式(推荐)
May 17 Javascript
微信小程序实现留言板
Oct 31 Javascript
自定义javascript验证框架示例【附源码下载】
May 31 Javascript
Vue 实现一个命令式弹窗组件功能
Sep 25 Javascript
Vue Element校验validate的实例
Sep 21 Javascript
vue实现简单的登录弹出框
Oct 26 #Javascript
让你30分钟快速掌握vue3教程
Oct 26 #Javascript
在vue项目中 实现定义全局变量 全局函数操作
Oct 26 #Javascript
vue3+typescript实现图片懒加载插件
Oct 26 #Javascript
原生js实现简单轮播图
Oct 26 #Javascript
vue项目开启Gzip压缩和性能优化操作
Oct 26 #Javascript
Vue检测屏幕变化来改变不同的charts样式实例
Oct 26 #Javascript
You might like
第六节 访问属性和方法 [6]
2006/10/09 PHP
php中filter_input函数用法分析
2014/11/15 PHP
javascript-TreeView父子联动效果保持节点状态一致
2007/08/12 Javascript
ASP.NET jQuery 实例1(在TextBox里面创建一个默认提示)
2012/01/13 Javascript
Jquery弹出窗口插件 LeanModal的使用方法
2012/03/10 Javascript
JavaScript事件委托的技术原理探讨示例
2014/04/17 Javascript
javascript将浮点数转换成整数的三个方法
2014/06/23 Javascript
JS 排序输出实现table行号自增前端动态生成的tr
2014/08/13 Javascript
javascript表单验证和Window详解
2014/12/11 Javascript
node.js [superAgent] 请求使用示例
2015/03/13 Javascript
贴近用户体验的Jquery日期、时间选择插件
2015/08/19 Javascript
CSS或者JS实现鼠标悬停显示另一元素
2016/01/22 Javascript
移动端翻页插件dropload.js(支持Zepto和jQuery)
2016/07/27 Javascript
Laravel中常见的错误与解决方法小结
2016/08/30 Javascript
如何重置vue打印变量的显示方式
2017/12/06 Javascript
Angular2实现组件交互的方法分析
2017/12/19 Javascript
vue2 全局变量的设置方法
2018/03/09 Javascript
angularJs中$scope数据序列化的实例
2018/09/30 Javascript
微信公众号生成新浪短网址的实现(快速生成)
2019/08/18 Javascript
js 判断当前时间是否处于某个一个时间段内
2019/09/19 Javascript
Python中使用Beautiful Soup库的超详细教程
2015/04/30 Python
浅谈python中scipy.misc.logsumexp函数的运用场景
2016/06/23 Python
python使用matplotlib绘制柱状图教程
2017/02/08 Python
python文件读写代码实例
2019/10/21 Python
Python tkinter实现图片标注功能(完整代码)
2019/12/08 Python
基于Python中random.sample()的替代方案
2020/05/23 Python
HTML高亮关键字的实现代码
2018/10/22 HTML / CSS
HTML5中外部浏览器唤起微信分享功能的代码
2020/09/15 HTML / CSS
印尼旅游网站:via
2017/11/12 全球购物
蛋糕店创业计划书
2014/05/06 职场文书
技校毕业生自荐书
2014/05/23 职场文书
幼儿园爱国卫生月活动总结
2014/06/30 职场文书
婚内房产协议书范本
2014/10/02 职场文书
2016高考感言
2015/08/01 职场文书
2016高校自主招生自荐信范文
2016/01/28 职场文书
WinServer2012搭建DNS服务器的方法步骤
2022/06/10 Servers