vue中的插槽的作用(vue三种插槽的区别)

vue中的插槽的作用(vue三种插槽的区别)p id main toc strong 文章目录 strong p 什么是插槽 一 匿名 默认插槽 二 后备内容 三 具名插槽 四 动态插槽 五 1 作用域插槽 2 作用域插槽动态绑定接受方法 六 vue2 和 vue3 插槽的区别和使用 什么是插槽 插槽就像放在组件中的占位标签

大家好,我是讯享网,很高兴认识大家。



 <p id="main-toc"><strong>文章目录</strong></p> 

讯享网

什么是插槽?

一:匿名/默认插槽 

二:后备内容

三:具名插槽

四:  动态插槽

五:(1)作用域插槽

        (2)作用域插槽动态绑定接受方法

六:vue2和vue3插槽的区别和使用

什么是插槽?
  • 插槽就像放在组件中的占位标签,使用组件时我们将要放到占位标签处的DOM结构写入组件标签体中即可。
  • 通俗点来讲,插槽就是在自定义组件中预留一个位置,这个位置的内容可以由使用组件的人来定义,可以通过属性等数据实现动态的内容展示及交互,具有高度的灵活性。

一:匿名/默认插槽 

        标签:&lt;slot&gt;&lt;/slot&gt;

        使用方法:

  •         插槽一般定义在子组件中,相当于一个占位。&lt;slot&gt;&lt;/slot&gt;
  •         父组件模板中的子组件标签要写成一对的样式,即:&lt;Category&gt;&lt;/Category&gt;
  •         这样&lt;Category&gt;&lt;/Category&gt;中的内容就会显示在子组件&lt;slot&gt;&lt;/slot&gt;标签的位置。
  •         如果&lt;Category&gt;&lt;/Category&gt;中没有内容,&lt;slot&gt;&lt;/slot&gt;标签中的内容就会显示在页面

示例代码:

在父级模板中使用该组件时,对应位置的内容会**入到默认插槽处:

讯享网

二:后备内容

此处所说的后备内容是官方文档里面的叫法,实际上就是指插槽的默认值。在定义组件时,可以在之间给出插槽的默认内容,也就是说当使用插槽时如果没有在组件标签内定义插槽的内容,则默认内容生效,否则默认内容不生效。

例如:定义组件插槽设置默认内容

 

不使用默认值,覆盖

讯享网

页面展示内容为:


讯享网

三:具名插槽

一个子组件可能有多个插槽,不同的插槽放置不同的内容,为了区分不同的插槽,每个插槽应该,这就是。

可以通过给  元素添加 name 属性来创建具名插槽,然后在父组件中使用 

v-slot :name  来引用具名插槽。

 

四:  动态插槽

在  上也是有效的,即可以定义下面这样的动态插槽名:

讯享网

五:(1)作用域插槽

作用域插槽的应用场景:
在中,而根据数据生成的在上。(插槽的使用者即使用子组件的父组件).

传递数据

因为(父组件)需要使用子组件的数据, 所以需要将数据从子组件传递到中。

  • 子组件的传递方法:利用插槽标签结合v-bind指令进行传递:

    可以传递多个数据

  • 父组件接收数据的方法有两种:默认作用域

默认作用域插槽接受方法

  • 接收的方法:通过子组件的指令直接接受一个插槽的对象。
    子组件传入插槽的作为指令的值可以在插槽内的表达式中访问。
 

具名作用域插槽接受方法

具名作用域插槽的工作方式和普通作用域插槽的工作方式类似,插槽的可以作为指令的值被访问到,也可以使用简写访问。

解构:

子组件传递props属性:

讯享网

父组件接受props属性:

 

父组件headerProps接受到的数据是 子组件标签的属性是不会传递给插槽的。

默认作用域插槽和具名作用域插槽一起使用:

当一起使用的时候相当于为默认插槽设置了一个的名字,使用标签和接受默认作用域插槽的属性值。具名作用域插槽正常使用即可。

讯享网

(2)作用域插槽动态绑定接受方法

插槽的使用者接收的方法:使用&lt;template&gt;&lt;/template&gt;标签的scope属性接收从子组件通过&lt;slot&gt;标签传递过来的所有数据,接收到的数据是一个对象。
也可以使用&lt;template&gt;&lt;/template&gt;标签的slot-scope属性接收数据。
scope和slot-scope接收数据支持解构赋值

注意:不需要name

 

使用:

  • 子组件category.vue —— 数据在子组件中
讯享网
  • 父组件App.vue() —— 结构在父组件中
 

无渲染组件

简单来说就是:只有逻辑内容没有渲染内容的子组件叫做无渲染组件,子组件的渲染通过具名插槽全权交给父组件渲染。

如果我们将这个概念拓展一下,可以想象的是,一些组件可能,视图输出通过作用域插槽全权交给了。我们将这种类型的组件称为

插槽总结

  • 插槽的作用:
    让父组件可以向子组件指定位置插入,也是一种组件间通信的方式,适用于。
    使用插槽的时候父组件向子组件传递的html内容,在组件实例对象的上存储着父组件向子组件传递的html内容

六:vue2和vue3插槽的区别和使用

Vue2和Vue3的插槽系统有一些差异,但基本概念相同。

  1. 默认插槽:

    在Vue2中,可以使用来定义默认插槽。在Vue3中,默认插槽不需要特殊标记,可以直接通过模板使用。

  2. 具名插槽:

    在Vue2中,可以通过来定义具名插槽,然后在父组件中使用来填充。在Vue3中,插槽的定义和使用方法保持一致,只是指令形式有所变化,使用代替。

  3. 作用域插槽:

    在Vue2中,可以通过传递数据到具名插槽,子组件通过来接收插槽。在Vue3中,使用来接收作用域插槽的数据,其中是一个包含传递数据的对象。


小讯
上一篇 2025-05-04 15:28
下一篇 2025-05-10 18:49

相关推荐

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容,请联系我们,一经查实,本站将立刻删除。
如需转载请保留出处:https://51itzy.com/kjqy/147415.html