视频1 视频21 视频41 视频61 视频文章1 视频文章21 视频文章41 视频文章61 推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37 推荐39 推荐41 推荐43 推荐45 推荐47 推荐49 关键词1 关键词101 关键词201 关键词301 关键词401 关键词501 关键词601 关键词701 关键词801 关键词901 关键词1001 关键词1101 关键词1201 关键词1301 关键词1401 关键词1501 关键词1601 关键词1701 关键词1801 关键词1901 视频扩展1 视频扩展6 视频扩展11 视频扩展16 文章1 文章201 文章401 文章601 文章801 文章1001 资讯1 资讯501 资讯1001 资讯1501 标签1 标签501 标签1001 关键词1 关键词501 关键词1001 关键词1501 专题2001
Vue中render函数基本用法(详细教程)
2020-11-27 19:39:24 责编:小采
文档


本篇文章主要介绍了Vue中render函数的使用方法,现在分享给大家,也给大家做个参考。

render函数

vue通过 template 来创建你的 HTML。但是,在特殊情况下,这种写死的模式无法满足需求,必须需要js的编程能力。此时,需要用render来创建HTML。

什么情况下适合使用render函数

在一次封装一套通用按钮组件的工作中,按钮有四个样式(default success error )。首先,你可能会想到如下实现

 <p v-if="type === 'success'">success</p>
 <p v-else-if="type === 'error'">error</p>
 <p v-else-if="type === 'warm'">warm</p>
 <p v-else>default</p>

这样写在按钮样式少的时候完全没有问题,但是试想,如果需要的按钮样式有十多个,按钮内的文字根据实际情况而定(如success按钮内的文字可能是OK、GOOD等等)。那么template写死的方式就显得很无力了。遇上类似这样的情况,使用render函数可以说最优选择了。

根据实际情况改写按钮组件

首先render函数生成的内容相当于template的内容,故使用render函数时,在.vue文件中需要先把template标签去掉。只保留逻辑层。

export default {
 render(h) {
 return h('p',{
 'class': {
 btn: true,
 success: this.type === 'success',
 error: this.type === 'error',
 warm: this.type === 'warm',
 default: this.type === 'default'
 },
 domProps: {
 innerHTML: this.$slots.default[0].text
 },
 on: {
 click: this.clickHandle
 }
 })
 },
 methods: {
 clickHandle() {
 // dosomething
 }
 },
 props: {
 type: {
 type: String,
 default: 'default'
 },
 text: {
 type: String,
 default: 'default'
 }
 }
};

根据组件化思维,能抽象出来的东西绝不写死在逻辑上。这里的clickHandle函数可以根据按钮的type类型触发不同的逻辑,就不多叙述了。

然后在父组件调用

<btn
 v-for="(btn, index) in testData"
 :type="btn.type"
 :text="btn.text"
 :key="index">{{btn.text}}
</btn>

使用jsx

是的,要记住每个参数的类型同用法,按序传参实在是太麻烦了。那么其实可以用jsx来优化这个繁琐的过程。

return (
 <p
 class={{
 btn: true,
 success: this.type === 'success',
 error: this.type === 'error',
 warm: this.type === 'warm',
 default: this.type === 'default'
 }}
 onClick={this.clickHandle}>
 {this.$slots.default[0].text}
 </p>
)

示例二:

在遇到写类似的组件的时候需要写很多很长的代码,出于简洁(懒惰使人进步)的角度来说,我们应该找到更合适的方法来实现该效果。

 <body> 
 <p id="app"> 
 <mycomment :level="2"> 
 这是h2元素 
 </mycomment> 
 </p> 
 </body> 
 <script type="text/x-template" id="is"> 
 <p> 
 <h1 v-if="level === 1"> 
 <slot></slot> 
 </h1> 
 <h2 v-if="level === 2"> 
 <slot></slot> 
 </h2> 
 <h3 v-if="level === 3"> 
 <slot></slot> 
 </h3> 
 <h4 v-if="level === 4"> 
 <slot></slot> 
 </h4> 
 <h5 v-if="level === 5"> 
 <slot></slot> 
 </h5> 
 <h6 v-if="level === 6"> 
 <slot></slot> 
 </h6> 
 </p> 
</script> 
 <script> 
 Vue.component('mycomment',{ 
 template:'#is', 
 props:{ 
 level:{ 
 type:Number, 
 required:true, 
 } 
 } 
 }) 
 var app =new Vue({ 
 el:'#app', 
 }) 
 </script>

这时候Render 函数就很好的解决了这个问题,先来简单一点额例子,算是有基本的骨架了

 <body> 
 <p id="app"> 
 <render-teample :level="4"> 
 render function 
 
 </render-teample> 
 </p> 
 
</body> 
<script> 
Vue.component('render-teample',{ 
 render:function(createElement){ 
 return createElement( 
 'h'+this.level, 
 this.$slots.default 
 ) 
 }, 
 props: { 
 level: { 
 type: Number, 
 required: true 
 } 
} 
 var app=new Vue({ 
 el:"#app", 
 
 }); 
 </script>

然后进一步给你的组件加入你想要的样式需要事件,变得有血有肉

 <body> 
 <p id="app"> 
 <render-teample :level="4" > 
 
 <p class="jah" slot="myslot">render function</p> 
 </render-teample> 
 </p> 
 
 </body> 
 <script> 
 Vue.component('render-teample',{ 
 render:function(createElement){ 
 return createElement( 
 'h'+this.level, 
 { 
 'class':{ 
 show:true, 
 hide:false, 
 }, 
 style:{ 
 width:'200px', 
 height:'400px', 
 background:'red', 
 }, 
 attrs:{ 
 name:'h-ex', 
 id:'h-id' 
 }, 
 props:{ 
 myprops:true, 
 }, 
 on: { 
 click: function(event){ 
 alert(this.num) 
 } 
 }, 
 nativeOn:{ 
 click:function(event) { 
 
 alert(1111) 
 } 
 } 
 
 }, 
 [ 
 this.$slots.myslot, 
 createElement('p',{ 
 domProps:{ 
 innerHTML:'holle render' 
 } 
 }) 
 ] 
 
 ) 
 }, 
 props: { 
 level: { 
 type: Number, 
 required: true 
 } 
 } 
}); 
 var app=new Vue({ 
 el:"#app", 
 data:{ 
 num:110 
 } 
 }); 
 </script>

注意:约束组件中 VNodes 必须是唯一的。

直接把所有元素写在一个createElement()下是很痛苦的,不利于维护。

所以通常会

var com1= createElement('p','item1');var
com2= createElement('p','item1');

可以使用return createElement('p',[com1,com2])

这种情况是禁止的return createElement('p',[com1,com1])

上面是我整理给大家的,希望今后会对大家有帮助。

相关文章:

在Node.js中如何实现mysql事务自动回收连接

在JS数组中如何删除某个元素

详细介绍js中有关promise的知识点

下载本文
显示全文
专题