vue3中的render函数里定义插槽和使用插槽

 更新时间:2022年07月02日 10:59:35   作者:qq_42372534  
这篇文章主要介绍了vue3中的render函数里定义插槽和使用插槽方式,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教

render函数里定义插槽和使用插槽

vue3中this.slots和vue2的区别

vue3:this.slots是一个{ [name: string]: (…args: any[]) => Array | undefined }的对象,每个具名插槽的内容都要通过函数调用。如v-slot:foo插槽分发的内容通过this.slots.foo( )返回

vue2:this.slots是一个{ [name: string]: ?Array }的对象,v-slot:foo的内容通过this.slots.foo来访问 , 而this.scopedSlots才是和vue3里的this.$slots作用一样.

定义插槽

this.$slots.[插槽名] 这个一个返回VNode数组的函数,用于访问静态插槽内容.

const BlogPost = defineComponent({
  render(){
    return h('div', [
      h('h1',this.$slots.header&&this.$slots.header()||'默认header插槽'),
      h('p',this.$slots.default&&this.$slots.default({message:'我是作用域插槽的message'})||'默认default插槽'),
      h('h4',this.$slots.footer&&this.$slots.footer()||'默认footer插槽'),
    ])
  }
})
// 以上代码相当于以下的template
<template>
	<div>
		<h1>
			<slot name="header">默认header插槽</slot>
		</h1>
		<p>
			<slot>默认default插槽</slot>
		</p>
		<h4>
			<slot name="footer">默认footer插槽</slot>
		</h4>
	</div>
</template>

定义有插槽的组件使用插槽

在h函数的第三个参数中使用{ [name: string]: (…args: any[]) => Array | undefined }形式的对象来定义组件的具体插槽内容

const BlogPostWrapper = defineComponent({
  render(){
    return h('div',
             {style:'background:skyblue'},
             h(
                  BlogPost,
                   null,
                   {
                  header(props){
                    return '我是传进的header插槽内容'
                  },
                    default(props){
                    // 这里的props就是作用域插槽的插槽prop
                    return 'BlogPostWrapper的default插槽内容::>>'+props.message
                  },
                  footer(props){
                    return '我是传进的footer插槽内容'
                  }
                }
            )
          )
      }
})
// 相当于template
<template>
    <div>
        <BlogPost>
            <tempalte #header>'我是传进的header插槽内容'</tempalte>
            <tempalte #default="props">
                {{'BlogPostWrapper的default插槽内容::>>'+props.message}}
            </tempalte>
            <tempalte #footer>我是传进的footer插槽内容</tempalte>
        </BlogPost>
    </div>
</template>

vue3 render函数小变动

Render function API?是不是感觉有点陌生?那恭喜你,这个改动不会对你这位 <template> 用户造成影响。

老规矩,上帝视角看一下:

  • h需要从全局导入进来(不再是 render 函数的参数了)
  • render函数的参数改变了(为了在常规组件和函数组件中表现一致)
  • VNodes具备了扁平的属性结构

render函数的参数

2.x 这么写

在 Vue 2.x 的版本中,render 函数会以参数的形式自动接收 h 函数(aka:createElement):

export default {
    render(h) {
        return h('div');
    }
}

3.x 应该这么写

在即将到来的 Vue 3.x 版本中,h 函数需要手动从全局引入进来:

import { h } from 'vue';
 
export default {
    render() {
        return h('div');
    }
}

render函数签名

2.x 这么写

上面也提到了,2.x 的 render 函数会自动接收 h 作为参数:

export default {
    render(h) {
        return h('div');
    }
}

3.x 应该这么写

在 3.x 版本中,render 函数不再接收任何参数了,它仅存的主要作用就是在 setup 函数中使用。这样方便获取作用域链中的响应式状态以及各种函数,当然了,也方便获取任何传递给 setup 函数的参数。

import { h, reactive } from 'vue';
 
export default {
    setup(props, { slots, attrs, emit }) {
        const state = reactive({ count: 0 });
        
        function increment() {
            state.count++
        }
        
        // 返回一个 render 函数
        return () => {
            h(
                'div',
                { onClick: increment, },
                state.count,
            )
        }
    }
}

VNode属性格式

2.x 是这样的

domProps 是 VNode 属性中的一个“嵌套列表”:

{
    class: ['button', 'confirm-button'],
    style: { color: 'red' },
    attrs: { id: 'confirm' },
    domProps: { innerHTML: '' },
    on: { click: confirmCreate },
    key: 'submit-button',
}

3.x 中则是这样的

在 3.x 版本中,VNode 的所有属性都已经实现了“扁平化”的处理:

{
    class: ['button', 'confirm-button'],
    style: { color: 'red' },
    id: 'submit',
    innerHTML: '',
    onClick: confirmCreate,
    key: 'submit-button',
}

其实我也很少用 render 函数,毕竟 template 还是蛮香的。

如果想要获得更多的详细信息,请去这里:v3.vuejs.org/guide/migration/render-function-api.html(目前还没有中文版)

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • vue-cli脚手架-bulid下的配置文件

    vue-cli脚手架-bulid下的配置文件

    这篇文章主要介绍了vue-cli脚手架-bulid下的配置文件,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-03-03
  • vue-admin-element项目突然就起不来了的解决

    vue-admin-element项目突然就起不来了的解决

    这篇文章主要介绍了vue-admin-element项目突然就起不来了的解决方案,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-10-10
  • vue.js指令v-model实现方法

    vue.js指令v-model实现方法

    这篇文章主要为大家详细介绍了vue.js指令v-model实现方法,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2016-12-12
  • 浅析vue-router原理

    浅析vue-router原理

    这篇文章主要围绕Vue的SPA单页面设计展开。SPA(single page application):单一页面应用程序,有且只有一个完整的页面,对vue router原理感兴趣的朋友跟随小编一起看看吧
    2018-10-10
  • Vue+ ArcGIS JavaScript APi详解

    Vue+ ArcGIS JavaScript APi详解

    这篇文章主要介绍了Vue+ ArcGIS JavaScript APi,文中需要注意ArcGIS JavaScript3.x 和ArcGIS JavaScript 4.x框架差异较大,本文从环境搭建开始到测试运行给大家讲解的非常详细,需要的朋友可以参考下
    2022-11-11
  • 大前端代码重构之事件拦截iOS Flutter Vue示例分析

    大前端代码重构之事件拦截iOS Flutter Vue示例分析

    这篇文章主要为大家介绍了大前端代码重构之事件拦截iOS Flutter Vue示例分析,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-04-04
  • vue中利用mqtt服务端实现即时通讯的步骤记录

    vue中利用mqtt服务端实现即时通讯的步骤记录

    前些日子了解到mqtt这样一个协议,可以在web上达到即时通讯的效果,所以下面这篇文章主要给大家介绍了关于vue中如何利用mqtt服务端实现即时通讯的相关资料,需要的朋友可以参考下
    2021-07-07
  • Vue移动端右滑屏幕返回上一页附源码下载

    Vue移动端右滑屏幕返回上一页附源码下载

    这篇文章主要介绍了Vue移动端右滑屏幕返回上一页,本文结合实例给大家介绍的非常详细,并附有源码下载,需要的朋友可以参考下
    2019-06-06
  • vue点击弹窗自动触发点击事件的解决办法(模拟场景)

    vue点击弹窗自动触发点击事件的解决办法(模拟场景)

    本文通过案例场景给大家介绍vue点击弹窗自动触发点击事件的解决办法,通过两种方法给大家分享vue 自动触发点击事件的处理方法,对vue自动触发点击事件相关知识感兴趣的朋友一起看看吧
    2021-05-05
  • vue使用$store.commit() undefined报错的解决

    vue使用$store.commit() undefined报错的解决

    这篇文章主要介绍了vue使用$store.commit() undefined报错的解决方案,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-06-06

最新评论