this.$slots是vue里面的一个只读的api,用来访问被插槽分发的内容。每个具名插槽有其相应的 property (例如:v-slot:foo 中的内容将会在 vm.$slots.foo 中被找到)。default property 包括了所有没有被包含在具名插槽中的节点,或 v-slot:default 的内容。

这个api在日常用的不多,今天一个项目里控制列的展示中看到了这个api,然后惊奇的发现,在子组件的created里面打印this.$slots是一个空对象(请以JSON.parse(JSON.stringify())这种方式转换,因为对象后面会被赋值),在mounted里面打印才可以拿到。

这是因为在created阶段只是定义好了实例以及一些data,methods等基础属性,this.$slots这种属性只是进行了初始化定义,并没有真正赋值。而this.$slots其实会去寻找DOM元素对应的插槽,只有在mounted的阶段,DOM才被挂载成功。

Logo

前往低代码交流专区

更多推荐