精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

一個案例搞懂Vue.js的作用域插槽

開發 前端
當你無法理解一個東西的時候,最好的辦法就是在解決問題的過程中體會它的應用。本文將向你展示如何使用作用域插槽構建一個可復用的列表組件。

 [[279199]]

作用域插槽是 Vue.js 中一個很有用的特性,可以顯著提高組件的通用性和可復用性。問題在于,它實在不太好理解。嘗試搞清楚父子作用域之間錯綜復雜的關系,其痛苦程度不亞于求解一個棘手的數學方程。

當你無法理解一個東西的時候,最好的辦法就是在解決問題的過程中體會它的應用。本文將向你展示如何使用作用域插槽構建一個可復用的列表組件。

注意: 完整代碼可以去 Codepen    查看

最基礎的組件

我們即將構建的組件叫做 my-list ,用來展示一系列的項目。它的特別之處就在于,你可以在每次使用組件的時候自定義列表項目的渲染方式。

我們先從最簡單的單個列表開始:一個包含幾何圖形名字和邊數的數組。

app.js 

  1. Vue.component('my-list', {  
  2.   template: '#my-list',  
  3.   data() {  
  4.     return {  
  5.       title: 'Shapes',  
  6.       shapes: [   
  7.         { name: 'Square', sides: 4 },   
  8.         { name: 'Hexagon', sides: 6 },   
  9.         { name: 'Triangle', sides: 3 }  
  10.       ]  
  11.     };  
  12.   }  
  13. });  
  14. new Vue({  
  15.   el: '#app'  
  16. }); 

index.html 

  1. <div id="app">  
  2.   <my-list></my-list>  
  3. </div>  
  4. <script type="text/x-template" id="my-list">  
  5.   <div class="my-list">  
  6.     <div class="title">{{ title }}</div>  
  7.     <div class="list">  
  8.       <div class="list-item" v-for="shape in shapes">  
  9.         <div>{{ shape.name }} <small>({{ shape.sides }} sides)</small></div>  
  10.       </div>  
  11.     </div>  
  12.   </div>  
  13. </script> 

在加上一點樣式,大概就會是下圖這個樣子:

更通用的 my-list

現在我們想要讓 my-list 更加通用,可以渲染任何類型的列表。這次我們展示的是一堆顏色的名字以及對應的顏色方塊。

為此,我們需要將上例列表獨有的數據進行抽象化。由于列表中的項目可能有不同的結構,我們將會給 my-list 一個插槽,讓父組件來定義列表的展示方式。

app.js 

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

index.html 

  1. <script type="text/x-template" id="my-list">  
  2.   <div class="my-list">  
  3.     <div class="title">{{ title }}</div>  
  4.     <div class="list">  
  5.       <slot></slot>  
  6.     </div>  
  7.   </div>  
  8. </script> 

現在,我們在根實例中創建 my-list 組件的兩個實例,分別展示兩個測試用例列表:lists:

app.js 

  1. new Vue({  
  2.   el: '#app',  
  3.   data: {  
  4.     shapes: [   
  5.       { name: 'Square', sides: 4 },   
  6.       { name: 'Hexagon', sides: 6 },   
  7.       { name: 'Triangle', sides: 3 }  
  8.     ],  
  9.     colors: [  
  10.       { name: 'Yellow', hex: '#F4D03F', },  
  11.       { name: 'Green', hex: '#229954' },  
  12.       { name: 'Purple', hex: '#9B59B6' }  
  13.     ]  
  14.   }  
  15. });  
  1. <div id="app">  
  2.   <my-list :title="Shapes">  
  3.     <div class="list-item" v-for="item in shapes">  
  4.       <div>{{ shape.name }} <small>({{ shape.sides }} sides)</small></div>  
  5.     </div>  
  6.   </my-list>  
  7.   <my-list :title="Colors">  
  8.     <div class="list-item" v-for="color in colors">  
  9.       <div>  
  10.         <div class="swatch" :style="{ background: color.hex }"></div>  
  11.         {{ color.name }}  
  12.       </div>  
  13.     </div>  
  14.   </my-list>  
  15. </div> 

效果如下圖:

大材小用的組件

我們剛才創建的組件確實符合要求,但那段代碼算不上很好。my-list 本來應該是一個展示列表的組件,但我們卻把渲染列表需要的邏輯部分抽象到了父組件中,這樣一來,子組件在這里只不過是用來包裹列表而已,未免顯得大材小用了。

更糟糕的是,在兩個組件的聲明中存在著大量重復代碼(例如,<div class="list-item" v-for="item in ...">)。如果我們能夠在子組件中編寫這些代碼,那么子組件就不再是“打醬油的角色”了。

作用域插槽

普通插槽無法滿足我們的需求,這時候,作用域插槽就派上用場了。作用域插槽允許你傳遞一個模板而不是已經渲染好的元素給插槽。之所以叫做”作用域“插槽,是因為模板雖然是在父級作用域中渲染的,卻能拿到子組件的數據。

例如,帶有作用域插槽的組件 child 大概是下面這個樣子: 

  1. <div>  
  2.   <slot my-prop="Hello from child"></slot>  
  3. </div> 

使用這個組件的父組件將會在插槽中聲明一個 template 元素。這個模板元素會有一個 scope (譯者注:Vue 2.6 后改為 v-slot 屬性)屬性指向一個對象,任何添加到插槽(位于子組件模板)中的屬性都會作為這個對象的屬性。 

  1. <child>  
  2.   <template scope="props">  
  3.     <span>Hello from parent</span>  
  4.     <span>{{ props.my-prop }}</span>  
  5.   </template>  
  6. </child> 

將會渲染成: 

  1. <div>  
  2.   <span>Hello from parent</span>  
  3.   <span>Hello from child</span>  
  4. </div> 

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

我們將兩個列表數組通過 props 傳遞給 my-list。之后將普通插槽替換為作用域插槽,這樣,my-list 就能夠負責迭代列表項目,同時父組件依然能夠定義每個項目具體的展示方式。

index.html 

  1. <div id="app">  
  2.   <my-list title="Shapes" :items="shapes">  
  3.     <!--在這里書寫 template-->  
  4.   </my-list>  
  5.   <my-list title="Colors" :items="colors">  
  6.     <!--在這里書寫 template-->  
  7.   </my-list>     
  8. </div> 

接著我們讓 my-list 迭代項目。在 v-for 循環中,item 是當前迭代項目的別名。我們可以創建一個插槽并通過 v-bind="item" 將那個項目綁定到插槽中。

app.js 

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

index.html 

  1. <script type="text/x-template" id="my-list">  
  2.   <div class="my-list">  
  3.     <div class="title">{{ title }}</div>  
  4.     <div class="list">  
  5.       <div v-for="item in items">  
  6.         <slot v-bind="item"></slot>  
  7.       </div>  
  8.     </div>  
  9.   </div>  
  10. </script> 

注意:也許你之前沒見過不帶參數的 v-bind 用法。這種用法將會把整個對象的所以屬性都綁定到當前元素上。在涉及作用域插槽時,這種用法很常見,因為綁定的對象可能有很多屬性,而一一將它們列舉出來并手動綁定顯然太麻煩了。

現在,回到根實例這里來,在 my-list 的插槽中聲明一個模板。首先看一下幾何圖形列表(第一個例子中的列表),我們聲明的模板必須帶有一個 scope 屬性,這里將其賦值為 shape。shape 這個別名可以讓我們訪問作用域插槽。在模板中,我們可以繼續沿用最初例子中的標記來展示項目。 

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

整個模板大概是下面這樣: 

  1. <div id="app">  
  2.   <my-list title="Shapes" :items="shapes">  
  3.     <template scope="shape">  
  4.       <div>{{ shape.name }} <small>({{ shape.sides }} sides)</small></div>  
  5.     </template>  
  6.   </my-list>  
  7.   <my-list title="Colors" :items="colors">  
  8.     <template scope="color">  
  9.       <div>  
  10.         <div class="swatch" :style="{ background: color.hex }"></div>  
  11.         {{ color.name }}  
  12.       </div>  
  13.     </template>  
  14.   </my-list>     
  15. </div> 

結論

雖然用上作用域插槽之后,代碼量并未減少,但是我們將通用的功能都交由子組件負責,這顯著提高了代碼的健壯性。

完整代碼的 Codepen 在這里:

https://codepen.io/anthonygor...

譯者注: Vue.js 2.6.0 之后將 slot-scope 改為 v-slot

 

 

責任編輯:龐桂玉 來源: segmentfault
相關推薦

2020-05-25 17:03:47

Vue嵌套插槽開發

2024-01-16 12:19:08

MySQL重要機制高并發

2021-04-14 07:52:00

Vue 作用域插槽

2018-01-31 15:45:07

前端Vue.js組件

2011-03-31 11:15:52

網頁設計Web

2022-02-10 10:48:23

JavaScriptVue.js數據

2023-07-13 12:21:18

2022-04-05 16:44:59

系統Vue.js響應式

2025-09-03 02:46:00

Vue.js響應式變量

2019-04-29 14:51:05

前后端JavaVue.js

2022-04-09 17:53:56

Vue.js分支切換嵌套的effect

2011-03-04 10:07:34

Win7SQL Server連接

2023-03-07 16:09:08

2019-10-11 09:59:55

開發者技能工具

2020-12-07 06:26:32

模式交付工作

2020-04-30 09:17:28

數據分析電商分析思維

2023-04-26 01:25:05

案例故障模型

2022-01-13 22:37:26

VSCode代碼 編輯器

2020-03-24 08:32:24

vue作用域前端

2021-03-12 08:21:54

JavaScript 前端原生js
點贊
收藏

51CTO技術棧公眾號

欧美一级在线亚洲天堂| 欧美老女人在线| 欧美一二三区| 国产精品国产一区二区三区四区| 亚洲综合色网| 日韩久久免费电影| 亚洲精品www.| 成人一级福利| 国产精品久久久久久久久晋中 | 99综合电影在线视频| 日本午夜精品理论片a级appf发布| 超碰人人人人人人人| 高潮按摩久久久久久av免费| 欧美性猛交xxxx黑人交| 91精品在线影院| 白白色免费视频| 国产一区二区视频在线看 | 在线视频这里只有精品| 1204国产成人精品视频| 色8久久人人97超碰香蕉987| 韩国黄色一级大片| 四虎影视在线播放| 国产一区二区h| 日韩av日韩在线观看| 欧美成人aaa片一区国产精品| 九九视频精品全部免费播放| 日韩欧美在线1卡| 亚洲无吗一区二区三区| sm久久捆绑调教精品一区| 国产精品高潮呻吟| 欧美日韩在线观看一区| 后进极品白嫩翘臀在线视频| 麻豆精品精品国产自在97香蕉| 98精品国产高清在线xxxx天堂| 欧美a级片免费看| 精品久久电影| 精品亚洲一区二区三区在线观看 | 亚洲欧美日韩精品久久久久| 欧美二区三区在线| 日本黄色三级视频| 国产综合久久久久久鬼色| 国产成人啪精品视频免费网| 在线观看精品国产| 亚洲性色视频| 欧美日韩成人网| 手机在线免费看毛片| 日韩免费一区| 国产一区二区三区毛片| 国产aⅴ激情无码久久久无码| 国内精品偷拍| 亚洲国产成人在线视频| 亚洲一区二区三区四区av| 精品亚洲a∨一区二区三区18| 欧美日韩dvd在线观看| www.亚洲高清| 亚洲伦理久久| 欧美一卡二卡三卡| 天堂av.com| 警花av一区二区三区| 这里只有精品99re| 亚洲制服中文字幕| 欧美片网站免费| 欧美一级艳片视频免费观看| 无套内谢丰满少妇中文字幕 | 国内高清免费在线视频| 艳妇臀荡乳欲伦亚洲一区| 17c丨国产丨精品视频| 欧美黄色视屏| 狠狠躁夜夜躁人人躁婷婷91| 日韩欧美国产免费| 忘忧草在线www成人影院| 在线精品视频一区二区三四| 一区二区xxx| 亚州欧美在线| 欧美成人一级视频| 五十路六十路七十路熟婆| 最新亚洲精品| 伊人久久精品视频| 日韩三级在线观看视频| 欧美成人首页| 午夜精品免费视频| 免费看日批视频| 麻豆成人91精品二区三区| 国产日韩在线视频| 丰满少妇在线观看bd| 91美女片黄在线| 日韩高清av| av免费网站在线观看| 亚洲国产精品视频| 成人免费毛片播放| 国产999精品在线观看| 精品福利在线导航| 亚洲午夜久久久久久久国产| 欧美在线网站| 国产成人精品av在线| 国产精品乱码久久久| 成人精品电影在线观看| 日本一区视频在线观看免费| av网站大全在线| 好吊成人免视频| av在线免费看片| 天堂av一区二区三区在线播放| 一区二区欧美久久| 久久久夜色精品| 日本在线不卡视频| 草莓视频一区| 在线看的av网站| 欧美日韩中文字幕日韩欧美| 欧美视频亚洲图片| 亚洲黄色录像| 欧美激情视频在线观看| 无码人妻精品一区二区三区9厂 | 91在线观看网站| 国产免费a∨片在线观看不卡| 洋洋成人永久网站入口| 中文字幕av专区| 欧洲亚洲成人| 欧美成人第一页| 波多野结衣视频在线观看| 高清日韩电视剧大全免费| 亚洲精品一区二区三区樱花| 多野结衣av一区| 日韩欧美中文字幕精品| 免费一级黄色录像| 亚洲免费婷婷| 91精品入口蜜桃| 日本黄色片在线观看| 在线亚洲免费视频| 免费日本黄色网址| 欧美特黄a级高清免费大片a级| 成人黄色av免费在线观看| 韩国三级在线观看久| 婷婷成人激情在线网| 永久免费看片在线观看| 国产精品久久久久久久| 国产精品电影网站| 全色精品综合影院| 偷偷要91色婷婷| 国产高潮视频在线观看| 国产综合网站| 国产成人av一区二区三区| 麻豆影院在线观看| 欧美精品在线观看播放| 亚洲精品国产精品国自| 日韩精品乱码免费| 欧美视频1区| 在线免费av资源| 日韩精品中文字| 91午夜精品亚洲一区二区三区| 97精品久久久午夜一区二区三区 | 午夜精品短视频| 亚洲伦乱视频| 尤物yw午夜国产精品视频明星| 91丨九色丨海角社区| 国产亚洲污的网站| 国内自拍视频网| 日韩伦理一区| 91|九色|视频| av丝袜在线| 日韩精品中文字幕一区| 国产在线欧美在线| a美女胸又www黄视频久久| www.com毛片| 国产调教一区二区三区| 国产精品久久久久秋霞鲁丝 | 青青草原国产在线视频| 天天综合一区| 国产不卡一区二区在线观看 | 欧美视频在线不卡| 9.1片黄在线观看| 韩国v欧美v日本v亚洲v| 日本人妻伦在线中文字幕| 欧美黄色影院| 国产精品对白刺激| 巨大荫蒂视频欧美大片| 亚洲精品在线三区| 久久久久久久久久成人| 国产精品黄色在线观看| 中文字幕一二三区| 国产日韩欧美三区| 亚洲精品高清国产一线久久| 国产精品免费精品自在线观看| 欧美激情欧美激情| 国产综合在线观看| 欧美一级欧美三级| 国产精品自拍99| 国产精品第五页| 亚洲天堂2024| 毛片av一区二区三区| 成人区一区二区| 欧美日韩在线二区| 成人动漫在线观看视频| 偷拍中文亚洲欧美动漫| 久久视频在线直播| 亚洲三区在线播放| 91精品欧美久久久久久动漫| 免费日韩一级片| 亚洲色欲色欲www| 法国伦理少妇愉情| 国产老肥熟一区二区三区| 国内外成人激情视频| 99久久99久久精品国产片果冰| 国产乱码精品一区二区三区日韩精品 | 亚洲一级片网站| 亚洲欧洲综合| 99精品视频网站| 久久av中文| 官网99热精品| 亚洲成人1区| 国产99在线|中文| av在线中出| 久久精品精品电影网| 蝌蚪视频在线播放| 精品国产一区二区在线观看| 国产精品热久久| 在线免费精品视频| 在线观看亚洲天堂| 亚洲激情欧美激情| 国产精品视频看看| 国产片一区二区三区| 午夜不卡久久精品无码免费| 国产真实乱子伦精品视频| 免费激情视频在线观看| 99精品视频网| 国产毛片久久久久久国产毛片| 日韩欧美精品一区| 日本视频一区在线观看| 男人的天堂久久| 波多野结衣一区二区三区在线观看 | 亚洲午夜激情网页| 色婷婷在线视频观看| 国产精品欧美极品| 成人在线手机视频| 国产日本欧美一区二区| 亚洲熟妇无码av| 91丨porny丨国产入口| 日本一卡二卡在线| 成人午夜激情在线| 风韵丰满熟妇啪啪区老熟熟女| 国产一区二区三区免费| 在线观看免费av网址| 蜜臀av一级做a爰片久久| 999精品网站| 久久人人97超碰国产公开结果| 欧美性久久久久| 先锋亚洲精品| 亚洲精品中文字幕无码蜜桃| 亚洲欧美日本国产专区一区| 97av视频在线观看| 久久九九电影| 三级a在线观看| 免费人成精品欧美精品| 色呦色呦色精品| 国产一区二区三区在线看麻豆| 手机av在线网站| 国产a精品视频| 老熟妇精品一区二区三区| av欧美精品.com| www.色多多| 国产人伦精品一区二区| 黑人と日本人の交わりビデオ| 国产精品网站导航| 国产日韩欧美在线观看视频| 亚洲精品欧美在线| 日韩 国产 在线| 色综合久久中文综合久久牛| 瑟瑟视频在线免费观看| 欧美日韩国产综合一区二区| 99精品在线视频观看| 欧美不卡123| 五月天婷婷视频| 国产亚洲精品一区二区| 老司机在线视频二区| 欧美激情图片区| 日本一道高清亚洲日美韩| 91九色综合久久| 欧美日韩破处| 一级做a爰片久久| 欧美日韩成人| 久草综合在线观看| 国产精品一区免费在线观看| 一区二区免费在线观看视频| 国产欧美在线观看一区| 天海翼在线视频| 五月天一区二区三区| 成人免费一区二区三区| 欧美va在线播放| 国产中文字幕在线观看| 欧美二区在线播放| 91精品韩国| 99r国产精品视频| 国产日产精品_国产精品毛片| 日本三日本三级少妇三级66| 一区二区91| 亚洲图片 自拍偷拍| 337p粉嫩大胆噜噜噜噜噜91av | 亚洲成人精品在线观看| 日韩久久久久久久久久| 亚洲成人aaa| 美女隐私在线观看| 人九九综合九九宗合| 欧美欧美在线| 一区二区三区不卡在线| 国产日韩欧美一区在线 | 久久精品视频在线看| 欧美日韩色视频| 欧美日韩国产区| 亚洲系列第一页| 国产视频精品一区二区三区| 宅男网站在线免费观看| 国产精品男人爽免费视频1| 激情亚洲另类图片区小说区| 性做爰过程免费播放| 日韩va亚洲va欧美va久久| 制服丝袜第一页在线观看| 亚洲免费在线视频| 中文字幕在线播出| 亚洲欧洲av一区二区| av中文字幕在线看| 1卡2卡3卡精品视频| 久久精品播放| 精品久久久久久久无码| 久久免费精品国产久精品久久久久| 青春草免费视频| 在线电影国产精品| 超碰97在线免费观看| 国产999精品久久久影片官网| 黄色欧美网站| 97视频在线免费| 福利一区福利二区| 日韩a级片在线观看| 欧美精品国产精品| av影片免费在线观看| 国产精品吹潮在线观看| 久久av电影| 成人性做爰aaa片免费看不忠| 久久综合av免费| 天天干天天干天天| 亚洲美女喷白浆| 亚洲插插视频| 蜜桃av噜噜一区二区三区| 亚洲全部视频| 五十路六十路七十路熟婆| 午夜亚洲福利老司机| 特级丰满少妇一级aaaa爱毛片| 欧美激情奇米色| 美女主播精品视频一二三四| 99在线免费视频观看| 波多野结衣一区二区三区 | 91精品国产品国语在线不卡| 免费黄色在线观看| 亚洲va码欧洲m码| 欧美国产另类| 亚洲免费观看在线| 亚洲成a天堂v人片| 无套内谢的新婚少妇国语播放| 欧美亚洲国产视频| 羞羞色国产精品网站| 欧美成人黑人猛交| 亚洲国产成人私人影院tom| 在线观看国产黄| 久久精品成人欧美大片古装| 国产精品毛片aⅴ一区二区三区| 久久综合亚洲精品| 成人午夜视频福利| 国产精品久久久久久人| 中日韩午夜理伦电影免费 | 国产美女一区视频| 精品久久sese| 日韩不卡一区二区| 国产少妇在线观看| 亚洲精品成人av| 外国电影一区二区| 亚洲色图都市激情| 成人国产精品免费观看动漫| 欧美一级淫片免费视频黄| 自拍偷拍亚洲区| 91精品国产乱码久久久竹菊| 中文字幕日本最新乱码视频| 国产精品理论在线观看| 国产黄色片免费观看| 欧美在线观看一区二区三区| 久久高清精品| 国产69视频在线观看| 在线观看网站黄不卡| 人人澡人人添人人爽一区二区| 久久久久久久久久久久久久一区 | 国产综合福利在线| 在线欧美视频| 欧美视频一区二区在线| 亚洲国产另类久久精品| 精品久久福利| 极品美女扒开粉嫩小泬| 成人免费在线播放视频| 色噜噜一区二区三区| 国产欧美亚洲精品| 国产亚洲毛片在线| 日韩在线中文字幕视频| 亚洲午夜小视频| 国产欧美自拍一区|