vue中的slot(插槽)

54 篇文章 4 订阅

一、slot 基本用法

插槽指允许将自定义的组件像普通标签一样插入内容

import Vue from 'vue'
// 定义组件componentOne 
const compoentOne = {
    template: `
        <div :style="style1">
            <slot></slot> // 定义插槽
        </div>
    `,
    data () {
        return {
            style1: {
                width: '200px',
                height: '200px'
                border: '1px solid #ccc'
            }
        }
    }   
}
调用组件
new Vue({
    components: {
        ComOne: componentOne 
    },
    el: '#id',
    data () {
        return {
            val1: '123'
        }
    },
    template: `
        <div>
            <com-one>
                <span>{{val1}}</span> // 使用插槽
            </com-one>
        </div>
    `
})

二、具名插槽

给具体的插槽命名,并在使用的时候传入插槽的名称

import Vue from 'vue'

// 定义组件componentOne 
const compoentOne = {
    template: `
        <div :style="style1">
            <div>
                <slot name="header"></slot> // 定义一个名称为header的插槽
            </div>
            <div>
                <slot name="body"></slot> // 定义一个名称为body的插槽
            </div>
        </div>
    `,
    data () {
        return {
            style1: {
                width: '200px',
                height: '200px'
                border: '1px solid #ccc'
            }
        }
    }   
}
调用组件
new Vue({
    components: {
        ComOne: componentOne 
    },
    el: '#id',
    data () {
        return {
            val1: '123',
            val2: '456'
        }
    },
    template: `
        <div>
            <com-one>
                <span slot="header">{{val1}}</span> // 使用插槽'header**重点内容**'
                <span slot="body">{{val2}}</span> // 使用插槽'body'
            </com-one>
        </div>
    `
})

三、作用域插槽

将定义插槽的变量作用域到使用插槽中

import Vue from 'vue'

// 定义组件componentOne 
const compoentOne = {
    template: `
        <div :style="style1">
            <slot :aa="val1" :bb="val2"></slot> // 给插槽传入变量
        </div>
    `,
    data () {
        return {
            style1: {
                width: '200px',
                height: '200px'
                border: '1px solid #ccc'
            },
            val1: 'slot1',
            val2: 'slot2'
        }
    }   
}
调用组件
new Vue({
    components: {
        ComOne: componentOne 
    },
    el: '#id',
    data () {
        return {
            val1: '123'
        }
    },
    template: `
        <div>
            <com-one>
                <span slot-scope="props">{{props.aa}}{{props.bb}}{{val1}}</span> // 定义插槽传入的对象props,并使用
            </com-one>
        </div>
    `
})

vue2.6以后对具名插槽和作用域插槽做了修改,但任然没有废弃之前语法

四、具名插槽(2.6以后)

有时候我们希望在指定的位置输出我们的子元素,这时候具名插槽就排上了用场。

<!--组件调用时-->
<MyFooter>
  <template v-slot:footer>
  <!--这里v-slot:后边的值与组件内的slot的name属性对应,也就是插槽的名称。-->
      <div>list</div>
  </template>
</MyFooter>
<!--书写组件时-->
<template>
    <div>
        {{age}}
        <div>
            <slot name='footer' />
            <!--这里name的值就是这个插槽的名称。-->
        </div>
    </div>
</template>

最后我们会在我们想要的位置将我们的元素放置。

五、作用域插槽(vue2.6以后)

作用域插槽的主要作用是在书写插槽内容时可以获取到插槽作用域的值。

<!--组件调用-->
 <ul>
   <myli>
   <template v-slot:footer="message">
       <div>{{message.aa}}</div>
   </template>
   </myli>
 </ul>
<!--书写组件时-->
 <template>
    <li>
        <slot name='footer' :aa="title">
        </slot>
    </li>
</template>
注意事项:

这里需要注意的是message是所有你绑定属性的集合,也就是你写的:aa=“title”会当做message的属性来实现。当然这里message可以换做其它的名称。
还可以作为组件通讯来回答

总结

v-slot的出现是为了代替原有的slot和slot-scope
简化了一些复杂的语法。
一句话概括就是v-slot :后边是插槽名称,=后边是组件内部绑定作用域值的映射。

Slot插槽
插槽就是父组件往子组件中插入一些内容。
有三种方式,默认插槽,具名插槽,作用域插槽

  1. 默认插槽就是把父组件中的数据,显示在子组件中,子组件通过一个slot插槽标签显示父组件中的数据
  2. 具名插槽是在父组件中通过slot属性,给插槽命名,在子组件中通过slot标签,根据定义好的名字填充到对应的位置。
  3. 作用域插槽是带数据的插槽,子组件提供给父组件的参数,父组件根据子组件传过来的插槽数据来进行不同的展现和填充内容。在标签中通过slot-scope来接受数据。
### 回答1: 感谢您的提问,我可以回答这个问题。在 Vue 插槽是一种将内容分发到组件指定位置的方式。通过使用 <slot> 标签,我们可以在组件定义插槽,并在使用该组件时,将内容插入到插槽。如果需要在插槽插入组件,可以使用 <component> 标签来实现。 ### 回答2: Vue插槽slot)是一种用来扩展组件的机制,允许我们在组件定义一些可插入的内容。可以将插槽看作是组件的占位符,通过插槽,我们可以将自定义的内容插入到组件。 在Vue,使用插槽非常简单。首先,在父组件定义一个插槽,可以使用`<slot>`标签来定义。例如: ```html <template> <div> <slot></slot> </div> </template> ``` 在子组件,我们可以使用`<父组件名></父组件名>`的形式来插入父组件的插槽。例如: ```html <template> <div> <父组件名> <p>插入到插槽的内容</p> </父组件名> </div> </template> ``` 这样,子组件的`<p>插入到插槽的内容</p>`就会被插入到父组件定义的插槽。 除了默认插槽外,Vue还支持具名插槽。具名插槽允许我们在组件定义多个插槽,并通过指定插槽的名称来插入内容。例如: ```html <template> <div> <slot name="header"></slot> <slot name="body"></slot> <slot name="footer"></slot> </div> </template> ``` 在子组件,我们可以使用`<template slot="插槽名称">插入的内容</template>`的形式来指定插入到具名插槽的内容。例如: ```html <template> <div> <父组件名> <template slot="header"> <p>插入到header插槽的内容</p> </template> <template slot="body"> <p>插入到body插槽的内容</p> </template> <template slot="footer"> <p>插入到footer插槽的内容</p> </template> </父组件名> </div> </template> ``` 这样,子组件的内容就会被插入到对应的具名插槽。 总结来说,Vue插槽机制非常灵活,可以满足不同组件的需求。通过插槽,我们可以在父组件定义一些可插入的内容,并在子组件指定要插入的内容,实现组件的扩展和定制。 ### 回答3: Vue插槽slot)是一种组件通信的方式,它允许父组件向子组件传递内容,使得子组件可以在特定位置插入具体的内容。 在Vue,使用插槽步骤如下: 1. 在父组件定义插槽。可以使用`<template>`标签或者具名插槽来定义插槽的位置。例如: ``` <template> <div> <slot></slot> </div> </template> ``` 2. 在父组件引用子组件,并在子组件标签使用插槽。例如: ``` <template> <div> <child-component> 这里是插入到插槽的内容 </child-component> </div> </template> ``` 3. 在子组件使用插槽。可以使用`<slot>`标签在子组件定义插槽的位置,也可以使用具名插槽来定义多个插槽位置。例如: ``` <template> <div> <slot></slot> </div> </template> ``` 通过上述步骤,父组件的内容将会通过插槽被传递到子组件,并在特定位置进行插入。 插槽的使用可以增强组件的灵活性,使得组件可以根据需要插入不同的内容,实现更加个性化的界面效果。同时,插槽也可以结合作用域插槽、具名插槽等特性,实现更加复杂的组件通信和内容控制逻辑。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

归途风景111

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值