Vue slot简单理解

情形一:

子组件定义了具名的slot,父组件使用具名的slotslot显示顺序为子组件定义slot的顺序

子组件:

 

Vue.component('child',{
        template:`<div class="child"><slot name="one"></slot><slot name="two"></slot></div>`
    });

 

父组件使用子组件:

<child>
        <h1 slot="two" class="two">woshi  two</h1>
        <h2 slot="one" class="one">woshi  one</h2>
</child>

显示顺序按照子组件slot定义的顺序。

情形二:

子组件定义了不具名的slot,父组件直接使用子组件,并可以直接在子组件中写内容

子组件:

 

Vue.component('btn',{
        template:`<div class="button">
    <slot></slot>
</div>`
    });

 

父组件:

<btn>
        按钮
</btn>

情形三:

子组件slot中定义了默认内容,如果父组件引入了子组件,且不写内容,则显示子组件默认内容,子组件定义的默认内容也可以提前加任何样式或赋予任何标签。但是slot标签上不可以加任何样式。如果父组件引入定义了slot的子组件,并且赋予了内容,则子组件默认的slot中的标签与样式不会加上去。如果想要给slot加样式,要加在父组件上。

子组件:

 

Vue.component('aaa',{
        template:`<div>
    <slot><h1 style="color:red">woshi slot默认内容</h1></slot>
</div>`
});

 

父组件:

<aaa></aaa>
<aaa><h6>哈哈哈哈哈</h6></aaa>
<aaa>哈哈哈哈哈</aaa>

 

 vue dom元素挂载:

new Vue({
        el:"#app"
 })

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Vue的插槽(slot)是一种用于在组件中承载内容的机制。在Vue中,插槽的原理可以通过源码来解析。 首先,在Vue的组件中使用插槽的地方,会被编译成一个函数调用,具体代码是`_renderSlot(_ctx.$slots, "default", {count: _ctx.count})`。这个函数名叫`_renderSlot`。 `_renderSlot`函数的定义是这样的: ``` export function renderSlot( slots: Slots, name: string, props: Data = {}, fallback?: () => VNodeArrayChildren, noSlotted?: boolean ): VNode { // ... // 函数内部的实现逻辑 // ... return rendered } ``` 在这个函数内部,会先对插槽进行处理,保证插槽的内容是一个有效的VNode节点。然后,使用`createBlock`函数创建一个包含插槽内容的VNode节点。最后,将这个节点返回。 所以,Vue的插槽的原理就是,在编译时将插槽内容包装成一个函数,并使用`createBlock`函数创建一个包含插槽内容的VNode节点。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [vue插槽slot简单理解与用法实例分析](https://download.csdn.net/download/weixin_38630853/12927251)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 33.333333333333336%"] - *2* [Vue slot 详解](https://blog.csdn.net/huangyilinnuli/article/details/119272944)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 33.333333333333336%"] - *3* [vue slot的原理](https://blog.csdn.net/qq_36262295/article/details/116203390)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 33.333333333333336%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值