JavaScript--在Vue中使用插槽:slot
在Vue中使用插槽:slot
1、在子組件的template里可以直接使用slot標簽<slot></slot>,它可以顯示父組件向子組件插入的內(nèi)容。
2、slot標簽里面可以寫一些默認值,當父組件沒有插入內(nèi)容的時候它就會顯示默認值,插入內(nèi)容時就只顯示插入的內(nèi)容。
3、當使用多個slot標簽時,直接插入多個內(nèi)容時,每個slot標簽內(nèi)都會包括所有插入的內(nèi)容。
可以通過slot屬性給插入的不同內(nèi)容設置指定的名字,然后給相應的slot標簽設置相應的name屬性值,就可以讓該slot標簽顯示指定的插入內(nèi)容。
1、插槽是統(tǒng)稱,模板中的三個slot標簽都是插槽。
2、但是多個插槽需要區(qū)分,會分別設置一個name屬性。這個就叫做“具名插槽”,需要使用name屬性命名。
3、上面的是插入插槽的內(nèi)容,將某個名字的內(nèi)容插到子組件對應名字里面去。這里就是插入到name="footer"這個插槽中。
4、一般只有一個插槽的時候,不需要具名哦,多個才需要name來區(qū)分。
<div id="app">
<child>
<!-- <div slot="header">header</div> -->
<div slot="footer">footer</div>
</child>
</div>
<script>
Vue.component('child',{
//通過插槽slot可以更方便地向子組件傳遞元素,同時子組件使用插槽的內(nèi)容也非常簡單
template:`<div>
<slot name='header'>
<h6>header插槽內(nèi)容為空的默認值</h6>
</slot>
<div class="content">body</div>
<slot name='footer'></slot>
</div>`
})
var vm = new Vue({
el: "#app",
})
</script>
作用域插槽:使用template標簽包裹
1、<slot v-for='item of list' :item=item></slot>,只確定要對列表做一個循環(huán),但是列表的每一項怎么顯示由外部決定。
2、所以需要給子組件傳遞一個slot,首先一定要在最外層套一個template【固定寫法】(這就是作用域插槽),同時要寫一個slot-scope屬性(屬性值是自定義的)。(如:<template slot-scope='props'></template>,含義為子組件在使用slot的時候,會往slot里面?zhèn)鬟f一個item數(shù)據(jù),在上面使用子組件的時候就可以用這個數(shù)據(jù),這個數(shù)據(jù)就放在slot-scope屬性值中)
3、應該使用作用域插槽的情況:當子組件要做循環(huán)或者它的某一部分應該由外部傳遞進來的時候。
使用作用域插槽時,子組件可以向父組件的插槽里面?zhèn)鲾?shù)據(jù),父組件傳遞過來的插槽如果想接收這個數(shù)據(jù),必須在外層使用一個template,同時通過slot-scope對應的屬性名來接收傳遞過來的數(shù)據(jù)。
<div id="app">
<child>
<!--
父組件調(diào)用子組件時,給子組件插入一個作用域插槽template,
插槽里聲明一個從子組件接收的數(shù)據(jù)item放在slot-scope的屬性(props)里,然后通過H1模版方式展現(xiàn)
-->
<template slot-scope="props">
<li>{{props.item}} -hello</li>
</template>
</child>
</div>
<script>
Vue.component('child', {
data:function(){
return{
list:[1,2,3,4]
}
},
//當子組件用slot時,往slot里傳遞一個item的數(shù)據(jù),在父組件時就能用這個數(shù)據(jù)
template:`<div>
<ul>
<slot v-for="item of list" :item=item>
</slot>
</ul>
</div>`
})
var vm = new Vue({
el: "#app"
})
</script>
總結(jié)
本篇文章就到這里了,希望能給你帶來幫助,也希望您能夠多多關注腳本之家的更多內(nèi)容!
相關文章
JavaScript中Array.from()的用法總結(jié)
本文主要介紹了JavaScript中Array.from()的用法總結(jié)2023-05-05
JavaScript中的alert()函數(shù)使用技巧詳解
這篇文章主要介紹了JavaScript中的alert()函數(shù)使用技巧詳解,本文講解了普通彈出、帶換行的文本、使用制表符、使用變量、使用樣式等選擇,需要的朋友可以參考下2014-12-12
多瀏覽器兼容的動態(tài)加載 JavaScript 與 CSS
Omar AL Zabir這位MVP總是喜歡搞些稀奇古怪同時又很實用的小東西,并且還十分值得參考。最近他就做了一個叫做ensure的小工具用于動態(tài)加載JavaScript、CSS與HTML,而且IE、Firefox、Opera、Safari都支持了,那么我們就來看看ensure是如何做到動態(tài)加載JavaScript與CSS的。2008-09-09

