摘要:具名插槽適用于具有一定結(jié)構(gòu)且有多處不固定內(nèi)容的組件此時(shí)在定義組件時(shí)其實(shí)就是預(yù)留了多個(gè)空缺位置且分別命名如果只有一個(gè)當(dāng)然也可以采用具名插槽,但肯定不如默認(rèn)插槽,只會(huì)徒增配置成本。然后在使用時(shí)將內(nèi)容分成多塊分別命名成預(yù)留空缺位置的名字。
本文主要描述不才在學(xué)習(xí)Vue和Bootstrap中遇到的關(guān)于插槽的問(wèn)題及解決方案插槽理解
vue官網(wǎng)和很多熱心朋友又很多關(guān)于默認(rèn)插槽,具名插槽,插槽作用域相關(guān)的解釋,我就不重復(fù)搬過(guò)來(lái)占用篇幅了,這里簡(jiǎn)單的談?wù)勎覀€(gè)人的淺見(jiàn)。
插槽就是預(yù)留位置
插槽其實(shí)就是定義組件時(shí)預(yù)留的一些位置,將使用組件時(shí)組件內(nèi)額外的一些標(biāo)簽寫(xiě)入到對(duì)應(yīng)的預(yù)留位置就是插槽的作用了。
插槽適用于不固定內(nèi)容的組件
正是因?yàn)闊o(wú)法預(yù)見(jiàn)組件內(nèi)部所有可能的標(biāo)簽或內(nèi)容,所以干脆留一個(gè)空缺,全權(quán)交給使用者,想填啥就用啥。
具名插槽適用于具有一定結(jié)構(gòu)且有多處不固定內(nèi)容的組件
此時(shí)在定義組件時(shí)其實(shí)就是預(yù)留了多個(gè)空缺位置且分別命名(如果只有一個(gè)當(dāng)然也可以采用具名插槽,但肯定不如默認(rèn)插槽,只會(huì)徒增配置成本)。然后在使用時(shí)將內(nèi)容分成多塊分別命名成預(yù)留空缺位置的名字。
為什么要定義組件?
答:定義組件是一種封裝的形式,使用最簡(jiǎn)單的標(biāo)簽及屬性配置表達(dá)一大段比較豐富的結(jié)構(gòu)效果及一些數(shù)據(jù)和事件。
Anim pariatur cliche reprehenderit, enim eiusmod high life accusamus terry richardson ad squid. 3 wolf moon officia aute, non cupidatat skateboard dolor brunch. Food truck quinoa nesciunt laborum eiusmod. Brunch 3 wolf moon tempor, sunt aliqua put a bird on it squid single-origin coffee nulla assumenda shoreditch et. Nihil anim keffiyeh helvetica, craft beer labore wes anderson cred nesciunt sapiente ea proident. Ad vegan excepteur butcher vice lomo. Leggings occaecat craft beer farm-to-table, raw denim aesthetic synth nesciunt you probably haven"t heard of them accusamus labore sustainable VHS.
Anim pariatur cliche reprehenderit, enim eiusmod high life accusamus terry richardson ad squid. 3 wolf moon officia aute, non cupidatat skateboard dolor brunch. Food truck quinoa nesciunt laborum eiusmod. Brunch 3 wolf moon tempor, sunt aliqua put a bird on it squid single-origin coffee nulla assumenda shoreditch et. Nihil anim keffiyeh helvetica, craft beer labore wes anderson cred nesciunt sapiente ea proident. Ad vegan excepteur butcher vice lomo. Leggings occaecat craft beer farm-to-table, raw denim aesthetic synth nesciunt you probably haven"t heard of them accusamus labore sustainable VHS.
Anim pariatur cliche reprehenderit, enim eiusmod high life accusamus terry richardson ad squid. 3 wolf moon officia aute, non cupidatat skateboard dolor brunch. Food truck quinoa nesciunt laborum eiusmod. Brunch 3 wolf moon tempor, sunt aliqua put a bird on it squid single-origin coffee nulla assumenda shoreditch et. Nihil anim keffiyeh helvetica, craft beer labore wes anderson cred nesciunt sapiente ea proident. Ad vegan excepteur butcher vice lomo. Leggings occaecat craft beer farm-to-table, raw denim aesthetic synth nesciunt you probably haven"t heard of them accusamus labore sustainable VHS.
該示例代碼比較長(zhǎng)
結(jié)構(gòu)是很有規(guī)律的,很容易發(fā)現(xiàn)幾個(gè)共同的結(jié)構(gòu):card, card-header, card-body...
文案是具體的展示信息,也是我們希望組件能夠配置的
最精簡(jiǎn)的組件配置 Anim pariatur ...Anim pariatur ...Anim pariatur ...
header一般文本就夠用了,所以直接配置在標(biāo)簽屬性上
content, 如"Anim pariatur ..."我們預(yù)想其可能是其他的一個(gè)或多個(gè)組件甚至大段html(會(huì)有標(biāo)簽),此時(shí)放到屬性內(nèi)就不合適了,配置起來(lái)超級(jí)麻煩
組件封裝獲取header簡(jiǎn)單。遍歷$children從其attrs對(duì)象中可以讀取到,放到data中的一個(gè)數(shù)組里,采用v-for指令即可很容易渲染出來(lái)
獲取content不容易。$children都是虛擬DOM,反向變成html的API沒(méi)找到;再者就算找到了,同header一樣遍歷渲染出來(lái),也只是當(dāng)成字符串渲染出來(lái),加上v-html指令,標(biāo)準(zhǔn)的HTML標(biāo)簽倒是確實(shí)渲染出來(lái)了,可已定義的組件標(biāo)簽未能正確解析渲染(不知道vue有沒(méi)有相應(yīng)的API方法解決)。
插槽
具名插槽
問(wèn)題解決!
組件定義Vue.component("widget-collapse", { template: `組件使用`, data() { let children = this.$slots, items = []; for (let i in children) { let node = children[i][0]; if (node.tag) { items[i] = ({ header: VTool.attr(node, "header") || ("Item " + items.length), }) } } return { vitems: items } } })
組件優(yōu)化 Anim pariatur ...Anim pariatur ...Anim pariatur ...
使用時(shí)每個(gè)節(jié)點(diǎn)都寫(xiě)一個(gè)slot太累贅,容易寫(xiě)錯(cuò),刪除某個(gè)節(jié)點(diǎn)或調(diào)整節(jié)點(diǎn)順序后更改麻煩,能否程序動(dòng)態(tài)幫忙添加該slot屬性?
答:未找到對(duì)應(yīng)API,但對(duì)比默認(rèn)與具名插槽的$slots數(shù)據(jù)對(duì)象發(fā)現(xiàn)key分別為default和具名name
Vue.component("widget-collapse", { template: `刪除使用時(shí)的插槽命名`, data() { let children = this.$slots.default, items = []; for (let i = 0, len = children.length; i < len; i++) { let node = children[i]; if (node.tag) { let id = VTool.random(); this.$slots[id] = node; items.push({ id: id, header: VTool.attr(node, "header") || ("Item " + items.length), }) } } return { vitems: items } } })
同步更新 Anim pariatur ...Anim pariatur ...Anim pariatur ...
以上設(shè)置基本初始化是沒(méi)有任何問(wèn)題了,但在vue對(duì)象更新時(shí)會(huì)更改$slots對(duì)象
(經(jīng)跟蹤代碼查找到updateChildComponent方法內(nèi)在更新下層組件時(shí)執(zhí)行了vm.$slots = resolveSlots(renderChildren, parentVnode.context);覆蓋了之前縮處理過(guò)的$slots,且會(huì)在vm._render方法中重新渲染,且在此之前沒(méi)有公布任何事件,那就暴力覆蓋重寫(xiě)了)
Vue.component("widget-collapse", { ... created() { let _render = this._render; this._render = function() { let $slots = this.$slots; for (let name in $slots) { if (name !== "default") { return _render.apply(this, arguments); } } // 此時(shí)肯定是重新new的$slots, 重寫(xiě)對(duì)應(yīng)關(guān)系 let children = this.$slots.default, items = []; for (let i = 0, len = children.length; i < len; i++) { let node = children[i]; if (node.tag) { let id = VTool.random(); this.$slots[id] = node; items.push({ id: id, header: VTool.attr(node, "header") || ("Item " + items.length), }) } } this.vitems = items; return _render.apply(this, arguments); } }, ... })
本文對(duì)于vue插槽的處理辦法略顯暴力,但的確解決了我遇到的問(wèn)題,各位大拿有更好的經(jīng)驗(yàn)還請(qǐng)不吝賜教,拜謝!
文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/95602.html
摘要:具名插槽適用于具有一定結(jié)構(gòu)且有多處不固定內(nèi)容的組件此時(shí)在定義組件時(shí)其實(shí)就是預(yù)留了多個(gè)空缺位置且分別命名如果只有一個(gè)當(dāng)然也可以采用具名插槽,但肯定不如默認(rèn)插槽,只會(huì)徒增配置成本。然后在使用時(shí)將內(nèi)容分成多塊分別命名成預(yù)留空缺位置的名字。 本文主要描述不才在學(xué)習(xí)Vue和Bootstrap中遇到的關(guān)于插槽的問(wèn)題及解決方案 插槽理解 vue官網(wǎng)和很多熱心朋友又很多關(guān)于默認(rèn)插槽,具名插槽,插槽作用...
摘要:項(xiàng)目介紹旨在通過(guò)項(xiàng)目的形式同時(shí)學(xué)習(xí)和,實(shí)現(xiàn)一個(gè)在線配置頁(yè)面的功能。通過(guò)封裝好的組件樣式提供界面需要的組件,通過(guò)實(shí)現(xiàn)組件狀態(tài)更改及頁(yè)面渲染。 本文是不才在學(xué)習(xí)Vue和Bootstrap過(guò)程中遇到問(wèn)題解決的一些思路,主要描述了項(xiàng)目搭建,組件封裝、獲取、編輯、更新的一步步實(shí)現(xiàn),一些解決方案也沒(méi)找到正確的官方API,還請(qǐng)大拿們多多提點(diǎn)。 項(xiàng)目介紹 旨在通過(guò)項(xiàng)目的形式同時(shí)學(xué)習(xí)Vue和Bootst...
摘要:項(xiàng)目介紹旨在通過(guò)項(xiàng)目的形式同時(shí)學(xué)習(xí)和,實(shí)現(xiàn)一個(gè)在線配置頁(yè)面的功能。通過(guò)封裝好的組件樣式提供界面需要的組件,通過(guò)實(shí)現(xiàn)組件狀態(tài)更改及頁(yè)面渲染。 本文是不才在學(xué)習(xí)Vue和Bootstrap過(guò)程中遇到問(wèn)題解決的一些思路,主要描述了項(xiàng)目搭建,組件封裝、獲取、編輯、更新的一步步實(shí)現(xiàn),一些解決方案也沒(méi)找到正確的官方API,還請(qǐng)大拿們多多提點(diǎn)。 項(xiàng)目介紹 旨在通過(guò)項(xiàng)目的形式同時(shí)學(xué)習(xí)Vue和Bootst...
摘要:特意對(duì)前端學(xué)習(xí)資源做一個(gè)匯總,方便自己學(xué)習(xí)查閱參考,和好友們共同進(jìn)步。 特意對(duì)前端學(xué)習(xí)資源做一個(gè)匯總,方便自己學(xué)習(xí)查閱參考,和好友們共同進(jìn)步。 本以為自己收藏的站點(diǎn)多,可以很快搞定,沒(méi)想到一入?yún)R總深似海。還有很多不足&遺漏的地方,歡迎補(bǔ)充。有錯(cuò)誤的地方,還請(qǐng)斧正... 托管: welcome to git,歡迎交流,感謝star 有好友反應(yīng)和斧正,會(huì)及時(shí)更新,平時(shí)業(yè)務(wù)工作時(shí)也會(huì)不定期更...
摘要:中文官網(wǎng)英文官網(wǎng)組織發(fā)出一個(gè)問(wèn)題之后,不要暫時(shí)的離開(kāi)電腦,如果沒(méi)有把握先不要提問(wèn)。珍惜每一次提問(wèn),感恩每一次反饋,每個(gè)人工作還是業(yè)余之外抽出的時(shí)間有限,充分準(zhǔn)備好應(yīng)有的資源之后再發(fā)問(wèn),有利于問(wèn)題能夠高效質(zhì)量地得到解決。 Vue.js資源分享 更多資源請(qǐng)Star:https://github.com/maidishike... 文章轉(zhuǎn)自:https://github.com/maid...
閱讀 1002·2021-11-24 10:30
閱讀 2327·2021-10-08 10:04
閱讀 3968·2021-09-30 09:47
閱讀 1452·2021-09-29 09:45
閱讀 1445·2021-09-24 10:33
閱讀 6272·2021-09-22 15:57
閱讀 2358·2021-09-22 15:50
閱讀 4089·2021-08-30 09:45