詳解Vue 匿名、具名和作用域插槽的使用方法
Vue 中的插槽在開發(fā)組件的過程中其實(shí)是非常重要并且好用的。Vue 的插槽也沒有說很難使用,這篇文章簡(jiǎn)明扼要的介紹了三種插槽的用法。
匿名插槽
子組件定義 slot 插槽,但并未具名,因此也可以說是默認(rèn)插槽。只要在父元素中插入的內(nèi)容,默認(rèn)加入到這個(gè)插槽中去。 😵
<template> <div> hello <slot>陌生人</slot> </div> </template>
這里定義了一個(gè)默認(rèn)插槽,只要往里頭丟東西,就會(huì)被加入到這個(gè)插槽里面
slot 元素里面可以加入一系列后備內(nèi)容,一旦父元素沒有插入任何信息,那么就會(huì)渲染后備內(nèi)容。
<my-comp> oli </my-comp>
如在父組件中使用這個(gè)子組件,并插入 oli 字符串,效果如下:

具名插槽
具名插槽可以出現(xiàn)在不同的地方,不限制出現(xiàn)的次數(shù)。只要匹配了 name 那么這些內(nèi)容就會(huì)被插入到這個(gè) name 的插槽中去。
<template> <div> <slot name="nav"></slot> <br/> <slot name="content"></slot> <br/> <slot name="footer"></slot> </div> </template>
比如上述代碼定義了三個(gè)具名插槽。在父組件中即可使用 slot 屬性插入到對(duì)應(yīng)的插槽中:
<template> <div> <my-comp> <template slot="nav">navigator</template> <template slot="footer">footer</template> <template slot="content">content</template> </my-comp> </div> </template>
另外,順序并不重要,content 在 footer 下方但依然能夠按照 slot 定義的順序渲染:

作用域插槽
通常情況下普通的插槽是父組件使用插槽過程中傳入東西決定了插槽的內(nèi)容。但有時(shí)我們需要獲取到子組件提供的一些數(shù)據(jù),那么作用域插槽就排上用場(chǎng)了。 🤓
在子組件中創(chuàng)建 slot 并通過 v-bind 綁定數(shù)據(jù) prop 的形式傳入數(shù)據(jù):
<slot :data="data"></slot>
在組件 data 中創(chuàng)建數(shù)據(jù):
export default {
name: 'MyComp',
data () {
return {
data: { // 內(nèi)部狀態(tài)
username: 'oli'
}
}
}
}
這樣就可以在插槽中訪問到子元素的數(shù)據(jù)了:
<template v-slot:default="user">{{user.data.username}}</template>
也可以不書寫 default 關(guān)鍵字,默認(rèn)就是假定對(duì)應(yīng)默認(rèn)插槽
<template v-slot="user">{{user.data.username}}</template>
使用 v-slot 綁定一個(gè)命名空間 user,這樣就可以通過 user 對(duì)象引用到子組件中傳入的數(shù)據(jù)了
與具名插槽配合時(shí),需要明確書寫對(duì)應(yīng)的命名空間:
<template #:one="user">{{user.data.username}}</template>
<template #:another="user">{{user.data.username}}</template>
# 代表 v-slot 的縮寫,縮寫在有參數(shù)的情況下才會(huì)生效
動(dòng)態(tài)插槽名
另外,2.6 版本的 vue 還加入了動(dòng)態(tài)插槽名的功能,用來動(dòng)態(tài)的定義插槽名稱:
<template #:[dynamicSlotName]></template>
https://cn.vuejs.org/v2/guide...
PS:Vue作用域插槽使用實(shí)例詳解
這次給大家?guī)鞻ue作用域插槽使用詳解,Vue作用域插槽使用的注意事項(xiàng)有哪些,下面就是實(shí)戰(zhàn)案例,一起來看一下。
舉個(gè)例子,比如我寫了一個(gè)可以實(shí)現(xiàn)條紋相間的列表組件,發(fā)布后,使用者可以自定義每一行的內(nèi)容或樣式(普通的slot就可以完成這個(gè)工作)。而作用域插槽的關(guān)鍵之處就在于,父組件能接收來自子組件的slot傳遞過來的參數(shù),具體看案例和注釋。
<!DOCTYPE html>
<htmllang="en">
<head>
<metacharset="UTF-8">
<title>Vue作用域插槽</title>
<scriptsrc="https://cdn.bootcss.com/vue/2.3.4/vue.js"></script>
</head>
<body>
<pid="app2">
<my-stripe-list:items="users"odd-bgcolor="#D3DCE6"even-bgcolor="#E5E9F2">
<!-- props對(duì)象接收來自子組件slot的$index參數(shù) -->
<templateslot="cont"scope="props">
<span>{{users[props.$index].id}}</span>
<span>{{users[props.$index].name}}</span>
<span>{{users[props.$index].age}}</span>
<!-- 這里可以自定[編輯][刪除]按鈕的鏈接和樣式 -->
<a:href="'#edit/id/'+users[props.$index].id"rel="external nofollow">編輯</a>
<a:href="'#del/id/'+users[props.$index].id"rel="external nofollow">刪除</a>
</template>
</my-stripe-list>
</p>
<script>
Vue.component('my-stripe-list', {
/*slot的$index可以傳遞到父組件中*/
template: `
<p>
<pv-for="(item, index) in items"style="line-height:2.2;":style="index % 2 === 0 ? 'background:'+oddBgcolor : 'background:'+evenBgcolor">
<slotname="cont":$index="index"></slot>
</p>
</p>
`,
props: {
items: Array,
oddBgcolor: String,
evenBgcolor: String
}
});
new Vue({
el: '#app2',
data: {
users: [
{id: 1, name: '張三', age: 20},
{id: 2, name: '李四', age: 22},
{id: 3, name: '王五', age: 27},
{id: 4, name: '張龍', age: 27},
{id: 5, name: '趙虎', age: 27}
]
}
});
</script>
</body>
</html>
總結(jié)
以上所述是小編給大家介紹的Vue 匿名、具名和作用域插槽的使用方法,希望對(duì)大家有所幫助,如果大家有任何疑問請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!
如果你覺得本文對(duì)你有幫助,歡迎轉(zhuǎn)載,煩請(qǐng)注明出處,謝謝!
相關(guān)文章
vue項(xiàng)目本地開發(fā)完成后部署到服務(wù)器后報(bào)404錯(cuò)誤解決方案
很多時(shí)候我們發(fā)現(xiàn)辛辛苦苦寫的VueJs應(yīng)用經(jīng)過打包后在自己本地搭建的服務(wù)器上測(cè)試沒有什么問題,但真正放在服務(wù)器上后會(huì)發(fā)現(xiàn)或多或少的問題,這篇文章主要給大家介紹了關(guān)于vue項(xiàng)目本地開發(fā)完成后部署到服務(wù)器后報(bào)404錯(cuò)誤的解決方案,需要的朋友可以參考下2024-01-01
vue使用ECharts實(shí)現(xiàn)折線圖和餅圖
這篇文章主要為大家詳細(xì)介紹了vue使用ECharts實(shí)現(xiàn)折線圖和餅圖,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-09-09
vue之webpack -v報(bào)錯(cuò)解決方案總結(jié)
這篇文章主要介紹了vue之webpack -v報(bào)錯(cuò)解決方案總結(jié),本篇文章通過簡(jiǎn)要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下2021-09-09
解決vue admin element noCache設(shè)置無效的問題
今天小編就為大家分享一篇解決vue admin element noCache設(shè)置無效的問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2019-11-11
vue項(xiàng)目中l(wèi)oadsh庫常用方法說明
這篇文章主要介紹了vue項(xiàng)目中l(wèi)oadsh庫常用方法說明,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-11-11

