这篇文章主要介绍了vue如何使用render函数,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。
render 函数
在某些场景下你可能需要render 渲染函数带来的完全编程能力来解决不太容易解决的问题,特别是要动态选择生成标签和组件类型的场景。
1 动态标签
1. 一般情况
比如根据props来生成标签的场景
<template> <div> <div v-if="level === 1"> <slot></slot> </div> <p v-else-if="level === 2"> <slot></slot> </p> <h2 v-else-if="level === 3"> <slot></slot> </h2> <h3 v-else-if="level === 4"> <slot></slot> </h3> <strong v-else-if="level === 5"> <slot></slot> </stong> <textarea v-else-if="level === 6"> <slot></slot> </textarea> </div> </template>
其中level是data中的变量,可以看到这里有大量重复代码,如果逻辑复杂点,加上一些绑定和判断就更复杂了,这里可以利用 render 函数来对要生成的标签加以判断。
2.优化
使用 render 方法根据参数来生成对应标签可以避免上面的情况。
<template> <div> <child :level="level">Hello world!</child> </div> </template> <script type='text/javascript'> import Vue from 'vue' Vue.component('child', { render(h) { const tag = ['div', 'p', 'strong', 'h2', 'h3', 'textarea'][this.level] return h(tag, this.$slots.default) }, props: { level: { type: Number, required: true } } }) export default { name: 'hehe', data() { return { level: 3 } } } </script>
2 动态组件
当然render函数还有很多用法,比如要使用动态组件,除了使用 :is 之外也可以使用render函数
<template> <div> <button @click='level = 0'>嘻嘻</button> <button @click='level = 1'>哈哈</button> <hr> <child :level="level"></child> </div> </template> <script type='text/javascript'> import Vue from 'vue' import Xixi from './Xixi' import Haha from './Haha' Vue.component('child', { render(h) { const tag = ['xixi', 'haha'][this.level] return h(tag, this.$slots.default) }, props: { level: { type: Number, required: true } }, components: { Xixi, Haha } }) export default { name: 'hehe', data() { return { level: 0 } } } </script>
感谢你能够认真阅读完这篇文章,希望小编分享的“vue如何使用render函数”这篇文章对大家有帮助,同时也希望大家多多支持亿速云,关注亿速云行业资讯频道,更多相关知识等着你来学习!
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。