欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Vuejs第十一篇組件之slot內(nèi)容分發(fā)實例詳解

 更新時間:2016年09月09日 09:30:44   投稿:mrr  
這篇文章主要介紹了Vuejs第十一篇之slot內(nèi)容分發(fā)組件詳解的相關(guān)資料

什么是組件?

組件(Component)是 Vue.js 最強(qiáng)大的功能之一。組件可以擴(kuò)展 HTML 元素,封裝可重用的代碼。在較高層面上,組件是自定義元素,Vue.js 的編譯器為它添加特殊功能。在有些情況下,組件也可以是原生 HTML 元素的形式,以 is 特性擴(kuò)展。

Slot分發(fā)內(nèi)容

①概述:

簡單來說,假如父組件需要在子組件內(nèi)放一些DOM,那么這些DOM是顯示、不顯示、在哪個地方顯示、如何顯示,就是slot分發(fā)負(fù)責(zé)的活。

②默認(rèn)情況下

父組件在子組件內(nèi)套的內(nèi)容,是不顯示的。

例如代碼:

<div id="app"> 
<children> 
<span>12345</span> 
<!--上面這行不會顯示--> 
</children> 
</div> 
<script> 
var vm = new Vue({ 
el: '#app', 
components: { 
children: { //這個無返回值,不會繼續(xù)派發(fā) 
template: "<button>為了明確作用范圍,所以使用button標(biāo)簽</button>" 
} 
} 
}); 
</script> 

顯示內(nèi)容是一個button按鈕,不包含span標(biāo)簽里面的內(nèi)容;

③單個slot

簡單來說,只使用這個標(biāo)簽的話,可以將父組件放在子組件的內(nèi)容,放到想讓他顯示的地方。

<div id="app"> 
<children> 
<span>12345</span> 
<!--上面這行不會顯示--> 
</children> 
</div> 
<script> 
var vm = new Vue({ 
el: '#app', 
components: { 
children: { //這個無返回值,不會繼續(xù)派發(fā) 
template: "<button><slot></slot>為了明確作用范圍,所以使用button標(biāo)簽</button>" 
} 
} 
}); 
</script> 

例如這樣寫的話,結(jié)果是:

<button><span>12345</span>為了明確作用范圍,所以使用button標(biāo)簽</button>

即父組件放在子組件里的內(nèi)容,插到了子組件的<slot></slot>位置;

注意,即使有多個標(biāo)簽,會一起被插入,相當(dāng)于用父組件放在子組件里的標(biāo)簽,替換了<slot></slot>這個標(biāo)簽。

④具名slot

將放在子組件里的不同html標(biāo)簽放在不同的位置

父組件在要分發(fā)的標(biāo)簽里添加 slot=”name名” 屬性

子組件在對應(yīng)分發(fā)的位置的slot標(biāo)簽里,添加name=”name名” 屬性,然后就會將對應(yīng)的標(biāo)簽放在對應(yīng)的位置了。

示例代碼:

<div id="app"> 
<children> 
<span slot="first">12345</span> 
<span slot="second">56789</span> 
<!--上面這行不會顯示--> 
</children> 
</div> 
<script> 
var vm = new Vue({ 
el: '#app', 
components: { 
children: { //這個無返回值,不會繼續(xù)派發(fā) 
template: "<button><slot name='first'></slot>為了明確作用范圍,<slot name='second'></slot>所以使用button標(biāo)簽</button>" 
} 
} 
}); 
</script>

顯示結(jié)果為:(為了方便查看,已手動調(diào)整換行)

<button>
<span slot="first">12345</span>
為了明確作用范圍,
<span slot="second">56789</span>
所以使用button標(biāo)簽
</button>

⑤分發(fā)內(nèi)容的作用域:

被分發(fā)的內(nèi)容的作用域,根據(jù)其所在模板決定,例如,以上標(biāo)簽,其在父組件的模板中(雖然其被子組件的children標(biāo)簽所包括,但由于他不在子組件的template屬性中,因此不屬于子組件),則受父組件所控制。

示例代碼:

<div id="app"> 
<children> 
<span slot="first" @click="tobeknow">12345</span> 
<span slot="second">56789</span> 
<!--上面這行不會顯示--> 
</children> 
</div> 
<script> 
var vm = new Vue({ 
el: '#app', 
methods: { 
tobeknow: function () { 
console.log("It is the parent's method"); 
} 
}, 
components: { 
children: { //這個無返回值,不會繼續(xù)派發(fā) 
template: "<button><slot name='first'></slot>為了明確作用范圍,<slot name='second'></slot>所以使用button標(biāo)簽</button>" 
} 
} 
}); 
</script>

當(dāng)點擊文字12345的區(qū)域時(而不是按鈕全部),會觸發(fā)父組件的tobeknow方法。

但是點擊其他區(qū)域時則沒有影響。

官方教程是這么說的:

父組件模板的內(nèi)容在父組件作用域內(nèi)編譯;子組件模板的內(nèi)容在子組件作用域內(nèi)編譯

⑥當(dāng)沒有分發(fā)內(nèi)容時的提示:

假如父組件沒有在子組件中放置有標(biāo)簽,或者是父組件在子組件中放置標(biāo)簽,但有slot屬性,而子組件中沒有該slot屬性的標(biāo)簽。

那么,子組件的slot標(biāo)簽,將不會起到任何作用。

除非,該slot標(biāo)簽內(nèi)有內(nèi)容,那么在無分發(fā)內(nèi)容的時候,會顯示該slot標(biāo)簽內(nèi)的內(nèi)容。

如示例代碼:

<div id="app"> 
<children> 
<span slot="first">【12345】</span> 
<!--上面這行不會顯示--> 
</children> 
</div> 
<script> 
var vm = new Vue({ 
el: '#app', 
components: { 
children: { //這個無返回值,不會繼續(xù)派發(fā) 
template: "<div><slot name='first'><button>【如果沒有內(nèi)容則顯示我1】</button></slot>為了明確作用范圍,<slot name='last'><button>【如果沒有內(nèi)容則顯示我2】</button></slot>所以使用button標(biāo)簽</div>" 
} 
} 
}); 
</script> 

說明:

【1】name='first'的slot標(biāo)簽被父組件對應(yīng)的標(biāo)簽所替換(slot標(biāo)簽內(nèi)部的內(nèi)容被舍棄);

【2】name='last'的slot標(biāo)簽,因為沒有對應(yīng)的內(nèi)容,則顯示該slot標(biāo)簽內(nèi)部的內(nèi)容。

⑦假如想控制子組件根標(biāo)簽的屬性

【1】首先,由于模板標(biāo)簽是屬于父組件的,因此,將子組件的指令綁定在模板標(biāo)簽里,是不可以的(因為他歸屬于父組件);

【2】假如需要通過父組件控制子組件是否顯示(例如v-if或者v-show),那么這個指令顯然是屬于父組件的(例如放在父組件的data下面)??梢詫?biāo)簽寫在子組件的模板上。

如代碼:

<div id="app"> 
<button @click="toshow">點擊讓子組件顯示</button> 
<children v-if="abc"> 
</children> 
</div> 
<script> 
var vm = new Vue({ 
el: '#app', 
data: { 
abc: false 
}, 
methods: { 
toshow: function () { 
this.abc = !this.abc; 
} 
}, 
components: { 
children: { //這個無返回值,不會繼續(xù)派發(fā) 
template: "<div>這里是子組件</div>" 
} 
} 
}); 
</script>

說明:

通過父組件(點擊按鈕,切換v-if指令的值)控制子組件是否顯示。

【3】假如需要通過子組件,控制子組件是否顯示(比如讓他隱藏),那么這個指令顯然是屬于子組件的(會將值放在子組件的data屬性下),那么就不能像上面這么寫,而是必須放置在子組件的根標(biāo)簽中。

<div id="app"> 
<button @click="toshow">點擊讓子組件顯示</button> 
<children> 
<span slot="first">【12345】</span> 
<!--上面這行不會顯示--> 
</children> 
</div> 
<script> 
var vm = new Vue({ 
el: '#app', 
methods: { 
toshow: function () { 
this.$children[0].tohidden = true; 
} 
}, 
components: { 
children: { //這個無返回值,不會繼續(xù)派發(fā) 
template: "<div v-if='tohidden' @click='tohide'>這里是子組件</div>", 
data: function () { 
return { 
tohidden: true 
} 
}, 
methods: { 
tohide: function () { 
this.tohidden = !this.tohidden; 
} 
} 
} 
} 
}); 
</script>

說明:

點擊子組件會讓子組件消失;

點擊父組件的按鈕,通過更改子組件的tohidden屬性,讓子組件重新顯示。

子組件的指令綁定在子組件的模板之中(如此才能調(diào)用);

以上所述是小編給大家介紹的Vuejs第十一篇組件之slot內(nèi)容分發(fā)實例詳解,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!

相關(guān)文章

  • vue實現(xiàn)自定義組件掛載原型上

    vue實現(xiàn)自定義組件掛載原型上

    這篇文章主要介紹了vue實現(xiàn)自定義組件掛載原型上方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-08-08
  • vue中Echarts圖表寬度沒占滿的問題

    vue中Echarts圖表寬度沒占滿的問題

    這篇文章主要介紹了vue中Echarts圖表寬度沒占滿的問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-10-10
  • Vue3封裝自動滾動列表指令(含網(wǎng)頁縮放滾動問題)

    Vue3封裝自動滾動列表指令(含網(wǎng)頁縮放滾動問題)

    本文主要介紹了Vue3封裝自動滾動列表指令(含網(wǎng)頁縮放滾動問題),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-05-05
  • vue+element模態(tài)框中新增模態(tài)框和刪除功能

    vue+element模態(tài)框中新增模態(tài)框和刪除功能

    這篇文章主要介紹了vue+element模態(tài)框中新增模態(tài)框和刪除功能,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-06-06
  • VUE3+mqtt封裝解決多頁面使用需重復(fù)連接等問題(附實例)

    VUE3+mqtt封裝解決多頁面使用需重復(fù)連接等問題(附實例)

    最近了解到mqtt這樣一個協(xié)議,可以在web上達(dá)到即時通訊的效果,下面這篇文章主要給大家介紹了關(guān)于VUE3+mqtt封裝解決多頁面使用需重復(fù)連接等問題的相關(guān)資料,文中通過實例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2023-04-04
  • vue2/vue3路由權(quán)限管理的方法實例

    vue2/vue3路由權(quán)限管理的方法實例

    最近用vue框架做了個后臺管理項目,涉及權(quán)限,所以下面這篇文章主要給大家介紹了關(guān)于vue2/vue3路由權(quán)限管理的相關(guān)資料,需要的朋友可以參考下
    2021-06-06
  • vue實現(xiàn)表格分頁功能

    vue實現(xiàn)表格分頁功能

    這篇文章主要為大家詳細(xì)介紹了vue實現(xiàn)表格分頁功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-10-10
  • el-dialog關(guān)閉再打開后窗口內(nèi)容不刷新問題及解決

    el-dialog關(guān)閉再打開后窗口內(nèi)容不刷新問題及解決

    這篇文章主要介紹了el-dialog關(guān)閉再打開后窗口內(nèi)容不刷新問題及解決方案,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-02-02
  • Vue同一路由強(qiáng)制刷新頁面的實現(xiàn)過程

    Vue同一路由強(qiáng)制刷新頁面的實現(xiàn)過程

    這篇文章主要介紹了解決VUE同一路由強(qiáng)制刷新頁面的問題,本文給大家分享實現(xiàn)過程,通過實例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-08-08
  • Vue腳手架配置代理服務(wù)器的兩種方式(小結(jié))

    Vue腳手架配置代理服務(wù)器的兩種方式(小結(jié))

    本文主要介紹了Vue腳手架配置代理服務(wù)器的兩種方式(小結(jié)),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-01-01

最新評論