vue render函数动态加载img的src路径操作
分享一下我去如何解决vuerender中如何正确配置img的src路径?
一、我的项目中有俩层组件,
第一层父组件,第二层是render函数封装的组件,父组件调用render函数组件
二、render函数中需要创建标签,img中的src是父组件传进来的;
src正确传进来,图片却不不显示。
三、解决办法:
首先在父组件中将图片import进来,
importemptyfrom"./img/empty.png";
在父组件的data中声明一个变量,将empty图片引入进来
empty:empty,
父组件把图片传给子组件,子组件为
子组件在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时,需要用到vuesrc动态绑定
例如下面:
这里的tt就是渲染的内容,每个img的src需要根据tt的questionType去判断
我们首先为这个判断设置一个函数,并把它绑定到img.
typeIcon:function(kind){ switch(kind){ case1:returnrequire("../../assets/images/single_choice.png") break; case2:returnrequire("../../assets/images/multi_choice.png") break; case3:returnrequire("../../assets/images/matrix_single.png") break; case4:returnrequire("../../assets/images/matrix_multi.png") break; case5:returnrequire("../../assets/images/blank.png") break; default:returnrequire("../../assets/images/shortAnswer.png") } },
这里我们用一个switch语句,判断每个img对应的src。
这里需要注意的是:
返回src时,需要在src字符串前面加上require
最后,用:src绑定typeIcon
以上这篇vuerender函数动态加载img的src路径操作就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持毛票票。