vue中的插槽

一、插槽内容

  插槽内可以是任意内容。

  先看一下下面的代码:声明一个child-component组件,

  如果现在我想在<child-component></child-component>内放置一些内容,结果会是怎样?

复制代码
<div id="app">
    <child-component></child-component>

</div>
<script>
    Vue.component('child-component',{
        template:`
            <div>Hello,World!</div>
    })
    let vm = new Vue({
        el:'#app',
        data:{

        }
    })
</script>
复制代码
<child-component>你好</child-component>

 输出内容还是在组件中的内容,在 <child-component>内写的内容没起作用。

这就是插槽出现的作用。

 

我们现在给组件增加一个<slot></slot>插槽

我们在<child-component></child-component>内写的"你好"起作用了!!

 

Vue.component('child-component',{
        template:`
            <div>
            Hello,World!
            <slot></slot>
            </div>
    })

插槽就是Vue实现的一套内容分发的API,将<slot></slot>元素作为承载分发内容的出口。

没有插槽的情况下在组件标签内些一些内容是不起任何作用的,当我在组件中声明了slot元素后,在组件元素内写的内容

就会跑到它这里了!

 

二、具名插槽

具名插槽,就是给这个插槽起个名字

在组件中,我给插槽起个名字,一个名字叫"girl",一个名字叫"boy",还有一个不起名字。

然后再<child-component></child-component>内,slot属性对应的内容都会和组件中name一一对应。

而没有名字的,就是默认插槽!!

复制代码
<div id="app">
    <child-component>
        <template slot="girl">
            漂亮
        </template>
        <template slot="boy">
            帅气
        </template>
        <div>
            我是一类人,
            我是默认的插槽
        </div>
    </child-component>
</div>
<script>
    Vue.component('child-component',{
        template:`
            <div>
            <h4>男人和女人</h4>

            <slot name="girl"></slot>

            <div style="height:1px;background-color:red;"></div>

            <slot name="boy"></slot>

            <div style="height:1px;background-color:red;"></div>

            <slot></slot>
            </div>
        `
    })
    let vm = new Vue({
        el:'#app',
        data:{

        }
    })
</script>
复制代码

 

posted @   四水呐  阅读(313)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 25岁的心里话
· 闲置电脑爆改个人服务器(超详细) #公网映射 #Vmware虚拟网络编辑器
· 零经验选手,Compose 一天开发一款小游戏!
· 因为Apifox不支持离线,我果断选择了Apipost!
· 通过 API 将Deepseek响应流式内容输出到前端
点击右上角即可分享
微信分享提示