vue中插槽的本质是什么?

  • vue中slot插槽的本质是函数

    • 默认插槽: 一个名为default的函数

    • 命名插槽: 一个名为插槽名的函数

    • 作用域插槽: 一个带参数的函数

    声明一个带有插槽的组件Card

    • 正常写法
    xml 复制代码
    <template>
        <div>
            <slot name="title"/>
            <slot name="body"/>
            <slot :index="1" username="张三"/>
        </div>
    </template>
    • 下面这段代码和上面代码的作用是一样的, 每一个slot标签将来会编译成一个函数, 传递到组件内部.
      1. 没有name属性的slot会被编译为一个名为default的无参函数
      2. 有name属性的会被编译为一个以name属性值作为函数名的无参函数,
      3. 带有其他属性的slot标签会被编译为一个带参函数.
    xml 复制代码
    <script>
    import { h } from 'vue'
    export default {
        render() {
            // 在组件内部可以通过this.$slot获取插槽内容
            // 调用具名插槽函数
            const title = this.$slots.title()
            const body = this.$slots.body()
            // 调用默认作用域插槽函数
            const defaults = this.$slots.default({
                index: 1, username: '张三'
            })
            return h('div', {}, [
                defaults,
                title,
                body
            ])
        }
    }
    </script>

    调用一个带有插槽的组件Card

    xml 复制代码
    <template>
        <div>
            <Card>
                <!-- 会被编译为一个名为title的无参函数const title = ()=>{}, 传递给Card组件-->
                <template #title>
                    <h3>这是标题</h3>
                </template>
                <!-- 会被编译为一个名为body的无参函数const body = ()=>{}, 传递给Card组件-->
                <template #body>
                    <div>这是段落</div>
                </template>
                <!-- 会被编译为一个名为default的带参函数const default = (args)=>{}, 
                传递给Card组件-->
                <template v-slot="{ index, username }">
                    <div>{{ index }}-{{ username }}</div>
                </template>
            </Card>
        </div>
    </template>
    <script setup>
    import Card from './Card.vue'
    </script>
相关推荐
前端切图崽_小郭13 小时前
虚拟滚动:静态 vs 动态的核心差异与实现?
vue.js
白鲸开源16 小时前
Apache SeaTunnel Zeta Engine 的 Basic Auth 是怎么工作的?
java·vue.js·github
卤蛋fg616 小时前
vue 甘特图 vxe-gantt 的使用(四):周视图的渲染
vue.js
卤蛋fg616 小时前
vue 甘特图 vxe-gantt 的使用(三):月视图的渲染
vue.js
卤蛋fg618 小时前
vue 甘特图 vxe-gantt 的使用(一):年视图的渲染
vue.js
前端开发爱好者18 小时前
支持 110 种文件预览!兼容 Vue、React、Svelte!
前端·javascript·vue.js
秋天的一阵风1 天前
Vue 3 里被严重低估的 API:InjectionKey
前端·javascript·vue.js
徐小夕2 天前
万字拆解 JitWord:企业级实时协同文档底层架构 + 大模型 AI 融合完整实践
前端·vue.js·github
用户83134859306982 天前
Cesium实现雾气效果:按钮一键控制打开/关闭雾气效果,滑块拖动实时控制雾气浓度
vue.js·cesium
锋行天下2 天前
如何用Vite实现Vue组件的按需打包和远程加载
前端·vue.js·前端框架