vue3判断插槽内容是否为空

介绍

  • MyCom.vue
vue 复制代码
<div>
    <slot>默认内容</slot>
</div>
  • 组件使用
js 复制代码
<MyCom>
    <!-- comment -->
    <div v-for="item in list"/>
</MyCom>

我们尝试在MyCom组件内打印slots.default()数组,即使list长度为0,依然会打印长度为2的数组:

bash 复制代码
[{..., type: Symbol(v-cmt)}, {..., type: Symbol(v-fgt)}]

结果大概是这样的(其他字段省略,这里只讲type字段的值)。

Symbol(v-fgt)

  • 表示 片段节点 (Fragment Node)
  • 对应 Vue 模板中的 <template> 标签(当它用作包裹多个元素时)

Symbol(v-cmt)

  • 表示 注释节点 (Comment Node)
  • 对应模板中的 HTML 注释 <!-- comment -->

代码实现

当我们需要用到判断插槽内容是否为空这个条件去其他场景使用时,我们并不能像vue2一样,只通过判断slots.default().length就能知道插槽内容是否为空。

  • 我们需要过滤掉注释节点、空的片段节点,再判断其长度即可
js 复制代码
const slots = useSlots();
const isEmpty = computed(() => {
  if (!slots.default) return true;
  const slotsFilter = slots.default().filter((vnode) => {
    return (
      vnode.type !== Symbol.for("v-cmt") &&
      vnode.type === Symbol.for("v-fgt") &&
      !!vnode.children.length
    );
  });
  return slotsFilter.length === 0;
});
相关推荐
亲爱的小小安妮呀5 分钟前
CSS(2)
前端·css
Moment10 分钟前
不是只有服务能分布,类型也能分布:解密 TypeScript 分布式条件类型
前端·javascript·typescript
汪子熙11 分钟前
Angular NG04002 错误概述
前端·javascript·面试
spionbo21 分钟前
如何批量下载 vue 文件及相关操作指南
前端
yvvvy24 分钟前
《救命!原生 JS 差点把我 “送走”,直到遇见了 Vue 和 React…》
前端·javascript
每天都想睡觉的190026 分钟前
Vue 的 keep-alive 详解:作用、问题与优化
前端·vue.js
curdcv_po26 分钟前
🫴为什么看大厂的源码,看不到undefined,看到的是void 0
前端
就是我27 分钟前
Electron多窗口应用实战
前端·javascript·electron
芝士加29 分钟前
最全301/302重定向指南:从SEO到实战,一篇就够了
前端·javascript·面试
若梦plus29 分钟前
React19 状态管理方案与原理剖析
前端·react.js