成人怡红院-成人怡红院视频在线观看-成人影视大全-成人影院203nnxyz-美女毛片在线看-美女免费黄

站長資訊網(wǎng)
最全最豐富的資訊網(wǎng)站

詳解Vue.js中的作用域插槽

詳解Vue.js中的作用域插槽

作用域槽是Vue.js的一個有用特性,它可以使組件更加通用和可重用。唯一的問題是它們很難理解!試著讓你的頭在父母和孩子的范圍內(nèi)交織,就像解決一個棘手的數(shù)學(xué)方程。

當(dāng)你不能很容易地理解某件事時,一個好的方法是試著用它來解決問題。在本文中,我將演示如何使用作用域槽來構(gòu)建可重用列表組件。

詳解Vue.js中的作用域插槽

基本組成部分

我們要構(gòu)建的組件叫做my-list,它顯示了很多東西。該特性的特殊之處在于,您可以自定義列表項在每次使用組件時的呈現(xiàn)方式。

讓我們首先處理最簡單的用例,并獲取my-list來呈現(xiàn)一個列表:一個幾何形狀名稱數(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

<div id="app">   <my-list></my-list></div><script type="text/x-template" id="my-list">   <div class="my-list">     <div class="title">{{ title }}</div>     <div class="list">       <div class="list-item" v-for="shape in shapes">         <div>{{ shape.name }} <small>({{ shape.sides }} sides)</small></div>       </div>     </div>   </div> </script>

添加了一點(diǎn)CSS后,將會如下圖所示:

詳解Vue.js中的作用域插槽

泛化my-list

現(xiàn)在,我們想要使my-list功能足夠多,以呈現(xiàn)任何類型的列表。第二個測試用例將是一個顏色列表,包括一個小樣本來顯示顏色。

為此,我們必須抽象特定于形狀列表的任何數(shù)據(jù)。由于列表中的項的結(jié)構(gòu)可能不同,我們將為my-list提供一個插槽,以便父列表可以定義任何特定列表的顯示方式。

app.js

Vue.component('my-list', {   template: '#my-list',   props: [ 'title' ] });

index.html

<script type="text/x-template" id="my-list">   <div class="my-list">     <div class="title">{{ title }}</div>     <div class="list">       <slot></slot>     </div>   </div> </script>

現(xiàn)在讓我們在根實(shí)例中創(chuàng)建my-list組件的兩個實(shí)例來顯示我們的兩個測試用例列表:

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' }     ]   } });
<div id="app">   <my-list :title="Shapes">     <div class="list-item" v-for="item in shapes">       <div>{{ shape.name }} <small>({{ shape.sides }} sides)</small></div>     </div>   </my-list>   <my-list :title="Colors">     <div class="list-item" v-for="color in colors">       <div>         <div class="swatch" :style="{ background: color.hex }"></div>         {{ color.name }}      </div>     </div>   </my-list></div>

就像這樣:

詳解Vue.js中的作用域插槽

表面成分

我們剛剛創(chuàng)建的代碼工作得很好,但是代碼并不好。my-list是按名稱顯示列表的組件。但是我們已經(jīng)抽象了所有將列表呈現(xiàn)到父列表中的邏輯。組件只是用一些表示標(biāo)記將列表包裝起來。

考慮到組件的兩個聲明中仍然有重復(fù)的代碼(例如<div class="list-item" v-for="item in…"

作用域的插槽

為了實(shí)現(xiàn)這一點(diǎn),我們將使用作用域槽而不是常規(guī)槽。作用域插槽允許您將模板傳遞給插槽,而不是傳遞呈現(xiàn)的元素。它被稱為“作用域”槽,因為盡管模板是在父作用域中呈現(xiàn)的,但它可以訪問特定的子數(shù)據(jù)。

例如,具有作用域插槽的組件子組件可能如下所示。

<div>   <slot my-prop="Hello from child"></slot> </div>

使用此組件的父組件將在槽中聲明模板元素。此模板元素將具有一個屬性范圍,該范圍指定別名對象。添加到slot(在子模板中)的任何道具都可以作為別名對象的屬性使用。

<child>   <template scope="props">     <span>Hello from parent</span>     <span>{{ props.my-prop }}</span>   </template> </child>

顯示為:

<div>   <span>Hello from parent</span>   <span>Hello from child</span> </div>

在my-list中使用作用域插槽

讓我們將列表數(shù)組作為道具傳遞給my-list。然后我們可以用作用域插槽替換插槽。這樣my-list就可以負(fù)責(zé)迭代列表項,但是父級仍然可以定義每個列表項應(yīng)該如何顯示。

index.html

<div id="app">   <my-list title="Shapes" :items="shapes">     <!--template will go here-->   </my-list>   <my-list title="Colors" :items="colors">     <!--template will go here-->   </my-list>    </div>

現(xiàn)在我們得到my-list來迭代這些項。在v-for循環(huán)中,item是當(dāng)前列表項的別名。我們可以創(chuàng)建一個槽,并使用v-bind="item"將該列表項綁定到槽。

app.js

Vue.component('my-list', {   template: '#my-list',   props: [ 'title', 'items' ] });

index.html

<script type="text/x-template" id="my-list">   <div class="my-list">     <div class="title">{{ title }}</div>     <div class="list">       <div v-for="item in items">         <slot v-bind="item"></slot>       </div>     </div>   </div> </script>

注意:如果您以前沒有見過v-bind在沒有參數(shù)的情況下使用,這將把整個對象的屬性綁定到元素。這對于作用域插槽非常有用,因為您綁定的對象通常具有任意屬性,現(xiàn)在不需要通過名稱指定這些屬性。

現(xiàn)在我們將返回到根實(shí)例,并在my-list的slot中聲明一個模板。首先查看形狀列表,模板必須包含我們?yōu)槠浞峙鋭e名形狀的scope屬性。這個別名允許我們訪問限定范圍的道具。在模板內(nèi)部,我們可以使用與以前完全相同的標(biāo)記來顯示形狀列表項。

<my-list title="Shapes" :items="shapes">   <template scope="shape">     <div>{{ shape.name }} <small>({{ shape.sides }} sides)</small></div>   </template> </my-list>

下面是完整的模板:

<div id="app">   <my-list title="Shapes" :items="shapes">     <template scope="shape">       <div>{{ shape.name }} <small>({{ shape.sides }} sides)</small></div>     </template>   </my-list>   <my-list title="Colors" :items="colors">     <template scope="color">       <div>         <div class="swatch" :style="{ background: color.hex }"></div>         {{ color.name }}       </div>     </template>   </my-list>    </div>

結(jié)論

盡管這種方法和以前一樣有很多標(biāo)記,但它將公共功能委托給了組件,從而實(shí)現(xiàn)了更健壯的設(shè)計。

以下是完整代碼的代碼頁:

https://codepen.io/anthonygore/pen/zExPZX

贊(0)
分享到: 更多 (0)
?
網(wǎng)站地圖   滬ICP備18035694號-2    滬公網(wǎng)安備31011702889846號
夜夜高潮天天爽欧美| 日本丰满的人妻HD高清在线| 妺妺窝人销魂体色www| 免费中国帅气体育生GARY | 亚洲AV日韩AⅤ无码网站| 亚洲AV综合AV一区二区三区| 亚洲另类自拍丝袜第五页| 永久免费啪啪的网站入口| 99国产精品久久久蜜芽 | 人妻含泪让粗大挺进| 色翁荡息又大又硬又粗又爽| 玩弄丰满人妻大BBWBBW| 亚洲成AV人片久久| 中国内射XXXX6981少妇| 爱丫爱丫影院在线观看免费| 国产Chinese男男做受g片| 国产线路3国产线路2| 久久99精品久久久久久9| 免费国产成人AⅤ观看| 日韩Av无码一区二区| 亚欧洲乱码视频一二三区| 亚洲一区精品人人爽人人躁| WWW亚洲精品久久久| 国产成人亚洲精品青草天美| 精华液一区二区区别| 男生白内裤自慰GV白袜男同| 久久久精品456亚洲影院| 征服丝袜旗袍人妻| ZOOM与人性ZOOM2023| 国产精品久久久久AV| 久久99精品国产麻豆| 欧州一级 片内射AV| 无码中文字幕AⅤ精品影院| 野花电影在线观看免费720| 锕锕锕锕锕锕锕锕好疼动免费 | CHINA真实VIDEOS另类| 国产成人亚洲综合无码精品| 久久精品国产精品亚洲毛片 | 久久伊人五月丁香狠狠色| 日本公妇在线观看中文版| 亚洲AV日韩AV高潮无码专区| 中文人妻熟妇乱又伦精品| 粉嫩一区二区三区性色AV| 精品国产一区AV天美传媒| 欧美日韩一区精品视频一区二| 图片小说视频一区二区| 内射无码专区久久亚洲| 无人区一线二线三线乱码 | 大陆老太XXXXXHD| 精品久久久久久久中文字幕| 欧美婷婷六月丁香综合色| 亚洲AV成人无码精品网站按| AⅤ成年女人毛片免费观看| 国产欧美日韩专区发布| 欧美xxxxx视频| 亚洲AV人无码激艳猛片服务器| 99视频国产精品免费观看| 国产美女裸体无遮挡免费视频| 美女扒开腿让男人桶爽| 无码视频免费一区二区三区| 18禁黄网站禁片免费观看香港 | 宝贝这么湿想要吗| 精品深夜AV无码一区二区老年 | 国产麻豆MD传媒视频| 欧美VA亚洲VA在线观看| 亚洲国产AV无码一区二区三区| 班长哭着说不能再C了视频 | 少妇人妻偷人精品一区二区| 欲求不満な人妻は毎晩隣人に| 国产精品露脸视频观看| 欧美性色欧美A在线播放| 亚洲欧美日韩另类| 国产成人无码AⅤ片在线观看你 | 亚洲欧美成人综合久久久| 东北浪妇王梅娟偷人视频| 免费A级毛片无码免费视频120| 小雪尝禁果又粗又大的中国地图 | 韩国三级在线观看| 色综合久久一区二区三区| 综合久久国产九一剧情麻豆| 国色天香精品一卡2卡3卡| 日韩人妻无码精品专区| 4D肉蒲团之性奴大战奶水| 精品无码久久久久久国产| 无码日韩人妻精品久久| 被老头一个晚上做了6次| 蜜芽久久人人超碰爱香蕉| 亚洲精品久久久久无码AV片软件 | 亚洲人成网站18禁止一区| 国产乱亲BBBB| 色噜噜人体337P人体| FREEHDⅩXXXXSEX| 巨粗进入警花哭喊求饶| 亚洲丰满熟妇乱XXXXX网站| 国产成人亚洲综合精品| 人人妻人人躁人人爽精品| 18禁美女黄网站色大片免费观看 | 精品国产AⅤ无码一区二区蜜桃 | 人妻无码第一区二区三区| 人妻丰满熟妇AV无码区APP| 亚洲一区无码中文字幕| 久久国产精品日本波多野结衣| 欧美人与动牲交A免费观看| 欧美致敬很多经典的黑白MV| 亚洲精品自产拍在线观看动漫| 野花高清完整版免费观看视频电视| 在线观看亚洲AV每日更新| 国产精品无码AV在线播放| 人妻无码中文字幕永久有效视频| 亚洲中文字幕人妻| 国产AV高潮社区| 久久精品国产亚洲精品| 人妻丰满AV中文久久不卡| 亚洲AV日韩精品久久久久久久 | 91人妻人人澡人人爽| 国产精品久久久久久久久久直播 | 老师的粉嫩小又紧水又多| 人妻av中年熟妇无码系列| 18级成人毛片免费观看| 久久永久免费人妻精品我不卡| 亚洲日韩欧洲无码A∨夜夜| 饥渴的少妇2中文字幕| 亚洲AV旡码高清在线观看| 国产老妇女婬片A级毛片| 污污网站18禁在线永久免费观看| 欧美人妻精品一区二区| 亚洲AV无码专区亚洲AV桃| 国产无遮挡又爽又黄大胸免费| 我和闺蜜在公交被八个人挤倒| 大象一区一品精区搬运机器| 日本免费不卡在线观看的NV| 波多野结衣50连登视频| 日本夜爽爽一区二区三区| 成 人 网 站国产免费观看| 日日摸日日碰夜夜爽无码| 第九午夜不卡影院| 图片区小说区偷拍区日韩| ASS鲜嫩鲜嫩PICS| 久久无码无码久久综合综合| 四季AV一区二区三区免费观看| JEAⅠOUSVUE丰满少妇| 欧美群妇大交乱视| 自拍偷自拍亚洲精品10P| 粉嫩av一区二区精品爆乳| 欧美人与性动交α欧美精品| 在教室伦流澡到高潮H强圩| 18禁肉肉无遮挡无码网站| 国产裸体歌舞一区二区| 小荡货奶真大水多好紧视频| 国精产品W灬源码1H855.C| 少妇人妻综合久久中文字幕| CHINESE性老妇老女人| 日本高清二区视频久二区| 暗交小拗女一区二| 日日摸日日碰夜夜爽亚洲| 国产妓女牲交A毛片| 亚洲AV日韩精品久久久久久A| 久久99精品久久久久久不卡| 中国熟妇内谢69XXXXX软件| 欧美日韩一区二区三区自拍| 吃奶呻吟打开双腿做受在线视频| 偷拍中国熟妇牲交| 精品国产三级A∨在线观看| 在公交上被灌满白浆的视频| 人妻无码久久中文字幕专区 | 国产成人AV一区二区三区在线观| 亚欧洲精品在线视频免费观看| 久艾草久久综合精品无码| 51精品人人搡人妻人人玩| 日韩人妻无码精品系列| 国精产品一二三四区产品| 姬小满开叉裙穿搭注意事项| 在线观看特色大片免费视频| 欧美VIDEO性欧美熟妇| 被吊起来张开腿供人玩弄| 日韩精品一区二区亚洲AV观看| 国产AV一区二区三区传媒| 亚洲AV成人精品日韩一区| 在线A毛片免费视频观看| 久久久亚洲精品无码| 中文无码VR最新无码AV专区| 午夜亚洲国产理论片2020| 精品午夜人成一区| 大J8黑人BBW巨大888| 伊人依成久久人综合网| 手机看片AV无码永久免费| 老司机亚洲精品影院| 国精产品W灬源码1688在线| JIZZJIZZ亚洲日本少妇| 亚洲欧洲日产V一个人免费观看视频WWW高清 | 欧美性色XXⅩXXA片HD| 国产亚洲人成在线播放| おやすみせくよ晚安免费影院| 亚洲精品人妻无码| 铜铜铜铜铜铜铜铜铜好多水 | 泳池里强摁做开腿呻吟| 亚洲 自拍 另类 欧美 综合| 四川丰满少妇被弄到高潮| 欧美肥胖老太大喷水| 久久亚洲欧美日本精品|