VUE-slot插槽-2020-10-27

slot元素作為VUE承載分發(fā)內(nèi)容的出口,也是組件的一塊HTML模板,這個(gè)塊模板顯示不顯示,以及怎樣顯示由父組件來決定;

1.默認(rèn)插槽: 又名單個(gè)插槽或者匿名插槽;這類插槽沒有具體的名字,一個(gè)組件只能有一個(gè)該類插槽.

<template>
<!-- 父組件 parent.vue -->
<div class="parent">
    <h1>父容器</h1>
    <child>
        <div class="tmpl">
            <span>菜單1</span>
        </div>
    </child>
</div>
</template>
<template>
<!-- 子組件 child.vue -->
<div class="child">
    <slot></slot>
    <h1>子組件</h1>
    <slot></slot>
</div>
</template>
結(jié)果展示

2. 具名插槽: 匿名插槽沒有name屬性,所以叫匿名插槽.那么增加了name屬性,就變成了具名插槽;具名插槽可以在組件中出現(xiàn)N次,出現(xiàn)在不同的位置,只需要不同的name屬性區(qū)分即可.

<template>
<!-- 父組件 parent.vue -->
<div class="parent">
    <h1>父容器</h1>
    <child>
        <div class="tmpl" slot="up">
            <span>菜單up-1</span>
        </div>
        <div class="tmpl" slot="down">
            <span>菜單down-1</span>
        </div>
        <div class="tmpl" slot="up">
            <span>菜單up-1</span>
        </div>
        <div class="tmpl" slot="default">
            <span>菜單->1</span>
        </div>
       <div class="tmpl">
            <span>菜單->10</span>
        </div>
    </child>
</div>
</template>
<template>
    <div class="child">
        <!-- 具名插槽 -->
        <slot name="up"></slot>
        <h3>這里是子組件</h3>
        <!-- 具名插槽 -->
        <slot name="down"></slot>
        <slot name="up"></slot>
        <!-- 匿名插槽 -->
        <slot></slot>
    </div>
</template>
結(jié)果展示

如上圖所示,slot標(biāo)簽會(huì)根據(jù)父容器給child標(biāo)簽內(nèi)傳入內(nèi)容的slot屬性值,替換對(duì)應(yīng)的內(nèi)容.

其實(shí),默認(rèn)插槽也有name屬性,為default,同樣指定slot的name值為default,一樣可以顯示父組件中傳入的沒有指定slot的內(nèi)容


3. 作用域插槽: 作用域插槽可以是默認(rèn)插槽,也可以是具名插槽,不一樣的地方是,作用域插槽可以為slot標(biāo)簽綁定數(shù)據(jù),讓父組件可以獲取子組件的數(shù)據(jù).

<template>
    <!-- parent.vue -->
    <div class="parent">
        <h1>這是父組件</h1>
        <child1>
            <template slot="default" slot-scope="slotProps">
                {{ slotProps }}
                <div v-for="item in slotProps" :key="item.id">
                    {{item.id}} --- {{item.name}} --- {{item.age}}
                </div>
            </template>
        </child1>
    </div>
</template>
<template>
    <!-- child.vue -->
    <div class="child">
        <h1>這是子組件</h1>
        <slot :user="user" :apple="apple"></slot>
    </div>
</template>
<script>
export default {
    data() {
        return {
            user: {
                id:1,
                name: '小趙',
                age:18
            },
            apple:{
                id:2,
                name:"red",
                age:100
            }
        }
    }
}
</script>
結(jié)果展示

如上圖所示,子組件child在渲染默認(rèn)插槽slot時(shí),將數(shù)據(jù)user傳遞給了slot標(biāo)簽,在渲染過程中,父組件可以通過slot-scope屬性獲取到user數(shù)據(jù)并渲染視圖


slot 實(shí)現(xiàn)原理:當(dāng)子組件vm實(shí)例化時(shí)丈积,獲取到父組件傳入的 slot 標(biāo)簽的內(nèi)容闻鉴,存放在vm.slot中畸颅,默認(rèn)插槽為vm.slot.default,具名插槽為vm.slot.xxx湃望,xxx 為 插槽名,當(dāng)組件執(zhí)行渲染函數(shù)時(shí)候,遇到<slot>標(biāo)簽晨雳,使用slot中的內(nèi)容進(jìn)行替換续挟,此時(shí)可以為插槽傳遞數(shù)據(jù)紧卒,若存在數(shù)據(jù),則可曾該插槽為作用域插槽诗祸。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末跑芳,一起剝皮案震驚了整個(gè)濱河市浇冰,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌聋亡,老刑警劉巖肘习,帶你破解...
    沈念sama閱讀 222,104評(píng)論 6 515
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異坡倔,居然都是意外死亡漂佩,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,816評(píng)論 3 399
  • 文/潘曉璐 我一進(jìn)店門罪塔,熙熙樓的掌柜王于貴愁眉苦臉地迎上來投蝉,“玉大人,你說我怎么就攤上這事征堪〈窭拢” “怎么了?”我有些...
    開封第一講書人閱讀 168,697評(píng)論 0 360
  • 文/不壞的土叔 我叫張陵佃蚜,是天一觀的道長(zhǎng)庸娱。 經(jīng)常有香客問我,道長(zhǎng)谐算,這世上最難降的妖魔是什么熟尉? 我笑而不...
    開封第一講書人閱讀 59,836評(píng)論 1 298
  • 正文 為了忘掉前任,我火速辦了婚禮洲脂,結(jié)果婚禮上斤儿,老公的妹妹穿的比我還像新娘。我一直安慰自己恐锦,他們只是感情好往果,可當(dāng)我...
    茶點(diǎn)故事閱讀 68,851評(píng)論 6 397
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著一铅,像睡著了一般陕贮。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上馅闽,一...
    開封第一講書人閱讀 52,441評(píng)論 1 310
  • 那天飘蚯,我揣著相機(jī)與錄音,去河邊找鬼福也。 笑死局骤,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的暴凑。 我是一名探鬼主播峦甩,決...
    沈念sama閱讀 40,992評(píng)論 3 421
  • 文/蒼蘭香墨 我猛地睜開眼,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來了凯傲?” 一聲冷哼從身側(cè)響起犬辰,我...
    開封第一講書人閱讀 39,899評(píng)論 0 276
  • 序言:老撾萬榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎冰单,沒想到半個(gè)月后幌缝,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 46,457評(píng)論 1 318
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡诫欠,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,529評(píng)論 3 341
  • 正文 我和宋清朗相戀三年涵卵,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片荒叼。...
    茶點(diǎn)故事閱讀 40,664評(píng)論 1 352
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡轿偎,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出被廓,到底是詐尸還是另有隱情坏晦,我是刑警寧澤,帶...
    沈念sama閱讀 36,346評(píng)論 5 350
  • 正文 年R本政府宣布嫁乘,位于F島的核電站昆婿,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏亦渗。R本人自食惡果不足惜挖诸,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 42,025評(píng)論 3 334
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望法精。 院中可真熱鬧,春花似錦痴突、人聲如沸搂蜓。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,511評(píng)論 0 24
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽帮碰。三九已至,卻和暖如春拾积,著一層夾襖步出監(jiān)牢的瞬間殉挽,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,611評(píng)論 1 272
  • 我被黑心中介騙來泰國打工拓巧, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留斯碌,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 49,081評(píng)論 3 377
  • 正文 我出身青樓肛度,卻偏偏與公主長(zhǎng)得像傻唾,于是被迫代替她去往敵國和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子承耿,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,675評(píng)論 2 359