-
vue中slot插槽的本质是函数
-
默认插槽: 一个名为default的函数
-
命名插槽: 一个名为插槽名的函数
-
作用域插槽: 一个带参数的函数
声明一个带有插槽的组件Card
- 正常写法
xml<template> <div> <slot name="title"/> <slot name="body"/> <slot :index="1" username="张三"/> </div> </template>- 下面这段代码和上面代码的作用是一样的, 每一个slot标签将来会编译成一个函数, 传递到组件内部.
- 没有name属性的slot会被编译为一个名为default的无参函数
- 有name属性的会被编译为一个以name属性值作为函数名的无参函数,
- 带有其他属性的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> -
vue中插槽的本质是什么?
Bruce7922024-10-13 11:56
相关推荐
一只蝉nahc4 小时前
vue使用iframe内嵌unity模型,并且向模型传递信息,接受信息MXN_小南学前端6 小时前
前端开发中 try...catch 到底怎么用?使用场景和最佳实践Z_Wonderful7 小时前
基于 Vite 的 React+Vue 混部完整模板(含目录结构、依赖清单、启动脚本)束尘9 小时前
Vue3 项目集成 OnlyOffice 在线编辑 + 自定义插件开发(二):插入功能全实现誰在花里胡哨9 小时前
Vue<前端页面装修组件>前端那点事9 小时前
Vue组件通信全场景详解(Vue2+Vue3适配)| 实战必备,新手也能看懂梦想CAD控件10 小时前
在线CAD开发包图纸转换功能使用指南费曼学习法10 小时前
虚拟 DOM 的 Diff 算法:Vue/React 如何实现高效更新前端那点事10 小时前
前端必看!console 调试不只有 log,这 8 个技巧省一半调试时间OpenTiny社区10 小时前
多端开发头疼?TinyVue 3.30 一招搞定,AI还帮你写代码!