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

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

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

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

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

當你不能很容易地理解某件事時,一個好的方法是試著用它來解決問題。在本文中,我將演示如何使用作用域槽來構(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>

添加了一點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)在讓我們在根實例中創(chuàng)建my-list組件的兩個實例來顯示我們的兩個測試用例列表:

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)到父列表中的邏輯。組件只是用一些表示標記將列表包裝起來。

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

作用域的插槽

為了實現(xià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就可以負責迭代列表項,但是父級仍然可以定義每個列表項應該如何顯示。

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

<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é)論

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

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

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

贊(0)
分享到: 更多 (0)
?
網(wǎng)站地圖   滬ICP備18035694號-2    滬公網(wǎng)安備31011702889846號
91夜黄性一交一乱一色一情人 | 国产精品秘 入口A级熟女| 国产激情З∠视频一区二区| 国产区图片区小说区亚洲区| 精品国产自产自在线观看蜜桃| 久久久久久久精品无码AV少妇| 免费看的WWW哔哩哔哩小说| 免费网站看V片在线18禁无码| 人妻少妇精品久久| 我的私人女教师3| 亚洲AV综合色区无码二区爱AV| 一二三四社区在线高清观看| MONSTER无删减动漫| 国产成人啪精品视频免费APP| 好儿子你插得太深了| 久久久无码人妻精品无码| 欧美最猛黑人XXXXWWW| 天天躁夜夜踩很很踩2022| 亚洲国产精彩中文乱码AV| √天堂8资源中文在线| 粗了大了 整进去好爽视频| 国产亚洲精品自在久久蜜TV| 久青草国产97香蕉在线影院| 人妻无码少妇一区二区| 性欧美18-19SEX性高清播| 一区二区三区av在线| 超碰97人人做人人爱少妇| 国产综合亚洲专区在线| 美女与野兽在线观看| 色欲AV伊人久久大香线蕉影院| 亚洲AV永久无码精品秋霞电影影院 | 欧美内射潮喷一区二虎| 无码精品国产一区二区免费 | 巨大黑人XXXXX高潮后处理| 日本熟妇WWW色视频在线播放| 亚洲AV无码男人的天堂| 69国产成人精品午夜福中文| 国产激情久久久久影院小草| 久久午夜无码鲁丝片秋霞| 日本极品少妇XXXXⅩOOO| 亚洲国产精品久久久久婷婷图片| CAOPORN免费公开视频| 国产亚洲欧美日韩剧的剧情介绍 | 亚洲AV无码专区青青草原| 91老熟女老女人国产老太毛多| 国产成人午夜福利在线小电影| 久久人与动人物A级毛片| 少妇99久久黑人| 一面膜上边一面膜下边日本 | 久久无码AV三级| 视频一区二区三区日韩| 与子乱刺激对白在线播放| 国产SUV精二区69| 麻豆专媒体一区二区| 无码人妻一区二区三区AV| 2023年最新绝伦推理片推荐| 国产午夜成人无码免费看| 欧美三级一区二区| 亚洲国产精品久久久久蜜桃网站| 成人免费A级毛片无码片2022| 精品一线二线三线无人区| 色欲天天综合亚洲日本| 中文字幕无码AV不卡一区 | 亚洲色偷偷综合亚洲AV伊人| 丰满熟妇大肉唇张开| 麻豆AV无码精品一区二区| 午夜亚洲WWW湿好大| АⅤ资源中文在线天堂| 久久久不卡国产精品一区二区| 窝窝人体色WWW聚色窝魅惑| Chinese老妇性饥渴老熟女| 精品乱码一区二区三区av| 色婷婷综合久久久久中文字幕 | 国产精品久久久久久TV| 欧美猛少妇色XXXXX猛叫| 亚洲午夜无码极品久久| 国产乱码一区二区三区| 人妻少妇精品中文字幕AV| 孕妇泬出白浆18P| 韩国午夜理伦三级在线观看仙踪林 | WWW.COM.含羞草| 久久亚洲熟妇熟女ⅩXXXHD| 无码熟妇人妻AV在线电影| 按摩师的巨大滑进我的身体| 久久亚洲日韩成人无码| 亚洲妇熟XXXX妇色黄无码| 丰满人妻一区二区三区Aⅴ在线| 欧美XXXX做受性欧美88| 亚洲一区二区三区无码中文字幕 | 亚洲另类激情综合偷自拍图| 国产激情久久久久影院老熟女免费| 人妻少妇精品无码专区漫画| 1024久久亚洲精品无码 | 永久AV狼友网站在线观看| 黑人异族XXXⅩ吊大| 玩弄粉嫩少妇高潮出白浆AⅤ| 边做饭边被躁BD小说| 男人放进女人里面叫什么| 一本色道久久88加勒比—综合| 精品成人乱色一区二区| 性色AV性色生活片| 国产精品爽爽V在线观看无码 | 国产香蕉97碰碰视频VA碰碰看 | 在线观看亚洲AV日韩A∨| 久久精品岛国AV一区二区无码| 亚洲AV无码精品国产成人| 国产精品怡红院在线观看| 天堂中文资源库官网| 二人世界免费观看正片在线观看| 人妻少妇精品无码专区二区| 99热国产这里只有精品无卡顿| 免费看视频高清在线观看| 又黑又肥的60岁岳| 久久天天躁狠狠躁夜夜躁2014| 亚洲日本一线产区和二线| 精品 亚洲 无码 自拍 另类| 亚洲AV无码成人网站国产网站| 国产精品一国产精品一K频道| 无码A级毛片视频| 国产风流老太婆大BBBHD视频| 特大巨黑吊性XXXX| 国产成人无码18禁午夜福利免费 | 99无人区码一码二码三码四码| 男男H黄漫画啪啪无遮挡| 中文字幕免费不卡二区| 免费无码AV片在线观看潮喷| 中文字幕乱码人妻一区二区三区| 乱色熟女综合一区二区三区| 伊伊人成亚洲综合人网香| 麻豆国产一卡二卡三卡| 中文字幕在线播放| 欧美变态另类ZOZO| 办公室紧身女教师| 色视频综合无码一区二区三区| 国产波霸爆乳一区二区| 无码一区二区波多野结衣播放搜索| 国产美女精品自在线拍免费| 亚洲AV成人午夜福利在线观看 | 在线观看免费AV网站| 奶头被几个流浪汉吃肿了| AV 日韩 人妻 黑人 综合| 人妻内射.PORN| 公交车上穿短裙被狂C| 无码色AV一二区在线播放| 国产综合在线观看| 亚洲色婷婷综合开心网| 美女裸体无遮挡免费视频网站| 99久久精品免费看国产一区二区| 人妻少妇无码精品视频区| 丰满妇女强高潮ⅩXXX| 午夜18禁自慰JK爆乳网站| 皇叔撞着小公主的小说叫什么| 亚洲自偷自偷偷色无码中文| 免费人成在线观看视频播放| 把八重神子焯出白水怎么办| 十八禁动漫露内裤扒开腿视频风险| 国产女人的高潮国语对白| 亚洲精品无码久久久久苍井空| 鲁丝片一区二区三区免费| CHINESE国产HD中国熟女| 少妇 精69XXXXXx白浆| 国产在线无码视频一区二区三区 | 贵阳40多岁熟女高潮呻吟| 亚州日本乱码一区二区三区| 久久精品国产72国产精| 97无码免费人妻超级碰碰夜夜| 色五月丁香六月欧美综合| 国偷自产视频一区二区久| 在线精品国产成人综合| 日韩精品内射视频免费观看| 国产人妻麻豆蜜桃色精品电影| 亚洲一区二区自偷自拍另类| 欧美性受XXXX88喷潮| 国产成人综合久久精品免费| 亚洲欧美中文日韩V在线观看不卡 亚洲欧美中文日韩V在线观看 | 成人H视频在线观看| 亚洲AV无码成人| 男女啪啪免费观看网站| 疯狂做爰XXXⅩ高潮69短| 亚洲精品欧美精品日韩精品| 欧美XXXX黑人又粗又长| 国产高清午夜人成在线观看| 亚洲熟妇少妇任你躁在线观看无码| 欧美黑人一级二级巨大久久天堂| 公交车被多男摁住灌浓精| 亚洲AV永久无码精品秋霞电影影| 农村人乱弄一区二区| 国产精品美女久久久久久2018| 亚洲熟伦熟妇AV无码专区| 人禽杂交18禁网站| 黑人av巨大粗吊| JAVAPARSER教师HD| 性一交一乱一伦一在线小视频| 美女裸体十八禁免费网站 | 巴西女人与禽2O2O性论交| 亚洲AV日韩AV永久无码水密桃| 女主播屁G裸露W身曝光| 国产偷久久久精品专区| A∨色狠狠一区二区三区| 亚洲AV成人噜噜无码网站|