十年網(wǎng)站開發(fā)經(jīng)驗(yàn) + 多家企業(yè)客戶 + 靠譜的建站團(tuán)隊
量身定制 + 運(yùn)營維護(hù)+專業(yè)推廣+無憂售后,網(wǎng)站問題一站解決
這篇文章主要介紹“Vue.js的作用域插槽的介紹以及使用場景”,在日常操作中,相信很多人在Vue.js的作用域插槽的介紹以及使用場景問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”Vue.js的作用域插槽的介紹以及使用場景”的疑惑有所幫助!接下來,請跟著小編一起來學(xué)習(xí)吧!
創(chuàng)新互聯(lián)建站-專業(yè)網(wǎng)站定制、快速模板網(wǎng)站建設(shè)、高性價比尼元陽網(wǎng)站開發(fā)、企業(yè)建站全套包干低至880元,成熟完善的模板庫,直接使用。一站式尼元陽網(wǎng)站制作公司更省心,省錢,快速模板網(wǎng)站建設(shè)找我們,業(yè)務(wù)覆蓋尼元陽地區(qū)。費(fèi)用合理售后完善,十多年實(shí)體公司更值得信賴。
作用域插槽是 Vue.js 中一個很有用的特性,可以顯著提高組件的通用性和可復(fù)用性。問題在于,它實(shí)在不太好理解。嘗試搞清楚父子作用域之間錯綜復(fù)雜的關(guān)系,其痛苦程度不亞于求解一個棘手的數(shù)學(xué)方程。
當(dāng)你無法理解一個東西的時候,最好的辦法就是在解決問題的過程中體會它的應(yīng)用。本文將向你展示如何使用作用域插槽構(gòu)建一個可復(fù)用的列表組件。

注意: 完整代碼可以去 Codepen 查看
最基礎(chǔ)的組件
我們即將構(gòu)建的組件叫做 my-list ,用來展示一系列的項(xiàng)目。它的特別之處就在于,你可以在每次使用組件的時候自定義列表項(xiàng)目的渲染方式。
我們先從最簡單的單個列表開始:一個包含幾何圖形名字和邊數(shù)的數(shù)組。
app.js
Vue.component('my-list', { template: '#my-list', data() { return { title: 'Shapes', shapes: [ { name: 'Square', sides: 4 }, { name: 'Hexagon', sides: 6 }, { name: 'Triangle', sides: 3 } ] }; } }); new Vue({ el: '#app' });index.html
在加上一點(diǎn)樣式,大概就會是下圖這個樣子:

更通用的 my-list
現(xiàn)在我們想要讓 my-list 更加通用,可以渲染任何類型的列表。這次我們展示的是一堆顏色的名字以及對應(yīng)的顏色方塊。
為此,我們需要將上例列表獨(dú)有的數(shù)據(jù)進(jìn)行抽象化。由于列表中的項(xiàng)目可能有不同的結(jié)構(gòu),我們將會給 my-list 一個插槽,讓父組件來定義列表的展示方式。
app.js
Vue.component('my-list', { template: '#my-list', props: [ 'title' ] });index.html
現(xiàn)在,我們在根實(shí)例中創(chuàng)建 my-list 組件的兩個實(shí)例,分別展示兩個測試用例列表:lists:
app.js
new Vue({ el: '#app', data: { shapes: [ { name: 'Square', sides: 4 }, { name: 'Hexagon', sides: 6 }, { name: 'Triangle', sides: 3 } ], colors: [ { name: 'Yellow', hex: '#F4D03F', }, { name: 'Green', hex: '#229954' }, { name: 'Purple', hex: '#9B59B6' } ] } }); {{ shape.name }} ({{ shape.sides }} sides) {{ color.name }}
效果如下圖:

大材小用的組件
我們剛才創(chuàng)建的組件確實(shí)符合要求,但那段代碼算不上很好。my-list 本來應(yīng)該是一個展示列表的組件,但我們卻把渲染列表需要的邏輯部分抽象到了父組件中,這樣一來,子組件在這里只不過是用來包裹列表而已,未免顯得大材小用了。
更糟糕的是,在兩個組件的聲明中存在著大量重復(fù)代碼(例如,
作用域插槽
普通插槽無法滿足我們的需求,這時候,作用域插槽就派上用場了。作用域插槽允許你傳遞一個模板而不是已經(jīng)渲染好的元素給插槽。之所以叫做”作用域“插槽,是因?yàn)槟0咫m然是在父級作用域中渲染的,卻能拿到子組件的數(shù)據(jù)。
例如,帶有作用域插槽的組件 child 大概是下面這個樣子:
使用這個組件的父組件將會在插槽中聲明一個 template 元素。這個模板元素會有一個 scope (譯者注:Vue 2.6 后改為 v-slot 屬性)屬性指向一個對象,任何添加到插槽(位于子組件模板)中的屬性都會作為這個對象的屬性。
Hello from parent {{ props.my-prop }}
將會渲染成:
Hello from parent Hello from child
在 my-list 中使用作用域插槽
我們將兩個列表數(shù)組通過 props 傳遞給 my-list。之后將普通插槽替換為作用域插槽,這樣,my-list 就能夠負(fù)責(zé)迭代列表項(xiàng)目,同時父組件依然能夠定義每個項(xiàng)目具體的展示方式。
index.html
接著我們讓 my-list 迭代項(xiàng)目。在 v-for 循環(huán)中,item 是當(dāng)前迭代項(xiàng)目的別名。我們可以創(chuàng)建一個插槽并通過 v-bind="item" 將那個項(xiàng)目綁定到插槽中。
app.js
Vue.component('my-list', { template: '#my-list', props: [ 'title', 'items' ] });index.html
注意:也許你之前沒見過不帶參數(shù)的 v-bind 用法。這種用法將會把整個對象的所以屬性都綁定到當(dāng)前元素上。在涉及作用域插槽時,這種用法很常見,因?yàn)榻壎ǖ膶ο罂赡苡泻芏鄬傩?,而一一將它們列舉出來并手動綁定顯然太麻煩了。
現(xiàn)在,回到根實(shí)例這里來,在 my-list 的插槽中聲明一個模板。首先看一下幾何圖形列表(第一個例子中的列表),我們聲明的模板必須帶有一個 scope 屬性,這里將其賦值為 shape。shape 這個別名可以讓我們訪問作用域插槽。在模板中,我們可以繼續(xù)沿用最初例子中的標(biāo)記來展示項(xiàng)目。
{{ shape.name }} ({{ shape.sides }} sides)
整個模板大概是下面這樣:
{{ shape.name }} ({{ shape.sides }} sides) {{ color.name }}
結(jié)論
雖然用上作用域插槽之后,代碼量并未減少,但是我們將通用的功能都交由子組件負(fù)責(zé),這顯著提高了代碼的健壯性。
到此,關(guān)于“Vue.js的作用域插槽的介紹以及使用場景”的學(xué)習(xí)就結(jié)束了,希望能夠解決大家的疑惑。理論與實(shí)踐的搭配能更好的幫助大家學(xué)習(xí),快去試試吧!若想繼續(xù)學(xué)習(xí)更多相關(guān)知識,請繼續(xù)關(guān)注創(chuàng)新互聯(lián)網(wǎng)站,小編會繼續(xù)努力為大家?guī)砀鄬?shí)用的文章!