这期内容当中小编将会给大家带来有关使用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路径了,如果刚好有类似的疑惑,不妨参照上述分析进行理解。如果想知道更多相关知识,欢迎关注亿速云行业资讯频道。
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。