Vuejs——組件——slot內容分發

2019獨角獸企業重金招聘Python工程師標準>>> hot3.png

①概述:

簡單來說,假如父組件需要在子組件內放一些DOM,那么這些DOM是顯示、不顯示、在哪個地方顯示、如何顯示,就是slot分發負責的活。

?

②默認情況下

父組件在子組件內套的內容,是不顯示的。

例如代碼:

<div id="app">  <children>  <span>12345</span>  <!--上面這行不會顯示-->  </children>  
</div>  
<script>  var vm = new Vue({  el: '#app',  components: {  children: {    //這個無返回值,不會繼續派發  template: "<button>為了明確作用范圍,所以使用button標簽</button>"  }  }  });  
</script>  

?

顯示內容是一個button按鈕,不包含span標簽里面的內容;

?

?

③單個slot

簡單來說,只使用這個標簽的話,可以將父組件放在子組件的內容,放到想讓他顯示的地方。

<div id="app">  <children>  <span>12345</span>  <!--上面這行不會顯示-->  </children>  
</div>  
<script>  var vm = new Vue({  el: '#app',  components: {  children: {    //這個無返回值,不會繼續派發  template: "<button><slot></slot>為了明確作用范圍,所以使用button標簽</button>"  }  }  });  
</script>  

?

例如這樣寫的話,結果是:

<button><span>12345</span>為了明確作用范圍,所以使用button標簽</button>

?

即父組件放在子組件里的內容,插到了子組件的<slot></slot>位置;

注意,即使有多個標簽,會一起被插入,相當于用父組件放在子組件里的標簽,替換了<slot></slot>這個標簽。

?

?

④具名slot

將放在子組件里的不同html標簽放在不同的位置

父組件在要分發的標簽里添加?slot=”name名”?屬性

子組件在對應分發的位置的slot標簽里,添加name=”name名”?屬性,

然后就會將對應的標簽放在對應的位置了。

?

示例代碼:

<div id="app">  <children>  <span slot="first">12345</span>  <span slot="second">56789</span>  <!--上面這行不會顯示-->  </children>  
</div>  
<script>  var vm = new Vue({  el: '#app',  components: {  children: {    //這個無返回值,不會繼續派發  template: "<button><slot name='first'></slot>為了明確作用范圍,<slot name='second'></slot>所以使用button標簽</button>"  }  }  });  
</script>  

?

顯示結果為:(為了方便查看,已手動調整換行)

<button><span slot="first">12345</span>為了明確作用范圍,<span slot="second">56789</span>所以使用button標簽</button>

?

⑤分發內容的作用域:

被分發的內容的作用域,根據其所在模板決定,例如,以上標簽,其在父組件的模板中(雖然其被子組件的children標簽所包括,但由于他不在子組件的template屬性中,因此不屬于子組件),則受父組件所控制。

?

示例代碼:

<div id="app">  <children>  <span slot="first" @click="tobeknow">12345</span>  <span slot="second">56789</span>  <!--上面這行不會顯示-->  </children>  
</div>  
<script>  var vm = new Vue({  el: '#app',  methods: {  tobeknow: function () {  console.log("It is the parent's method");  }  },  components: {  children: {    //這個無返回值,不會繼續派發  template: "<button><slot name='first'></slot>為了明確作用范圍,<slot name='second'></slot>所以使用button標簽</button>"  }  }  });  
</script>  

?

當點擊文字12345的區域時(而不是按鈕全部),會觸發父組件的tobeknow方法。

?

但是點擊其他區域時則沒有影響。

?

官方教程是這么說的:

父組件模板的內容在父組件作用域內編譯;子組件模板的內容在子組件作用域內編譯

?

?

?

⑥當沒有分發內容時的提示:

假如父組件沒有在子組件中放置有標簽,或者是父組件在子組件中放置標簽,但有slot屬性,而子組件中沒有該slot屬性的標簽。

?

那么,子組件的slot標簽,將不會起到任何作用。

?

除非,該slot標簽內有內容,那么在無分發內容的時候,會顯示該slot標簽內的內容。

?

如示例代碼:

<div id="app">  <children>  <span slot="first">【12345】</span>  <!--上面這行不會顯示-->  </children>  
</div>  
<script>  var vm = new Vue({  el: '#app',  components: {  children: {    //這個無返回值,不會繼續派發  template: "<div><slot name='first'><button>【如果沒有內容則顯示我1】</button></slot>為了明確作用范圍,<slot name='last'><button>【如果沒有內容則顯示我2】</button></slot>所以使用button標簽</div>"  }  }  });  
</script>  

說明:

【1】name=’first’的slot標簽被父組件對應的標簽所替換(slot標簽內部的內容被舍棄);

【2】name=’last’的slot標簽,因為沒有對應的內容,則顯示該slot標簽內部的內容。

?

?

?

⑦假如想控制子組件根標簽的屬性

【1】首先,由于模板標簽是屬于父組件的,因此,將子組件的指令綁定在模板標簽里,是不可以的(因為他歸屬于父組件);

?

【2】假如需要通過父組件控制子組件是否顯示(例如v-if或者v-show),那么這個指令顯然是屬于父組件的(例如放在父組件的data下面)。可以將標簽寫在子組件的模板上。

如代碼:

<div id="app">  <button @click="toshow">點擊讓子組件顯示</button>  <children v-if="abc">  </children>  
</div>  
<script>  var vm = new Vue({  el: '#app',  data: {  abc: false  },  methods: {  toshow: function () {  this.abc = !this.abc;  }  },  components: {  children: {    //這個無返回值,不會繼續派發  template: "<div>這里是子組件</div>"  }  }  });  
</script>  

?

說明:

通過父組件(點擊按鈕,切換v-if指令的值)控制子組件是否顯示。

?

?

【3】假如需要通過子組件,控制子組件是否顯示(比如讓他隱藏),那么這個指令顯然是屬于子組件的(會將值放在子組件的data屬性下),那么就不能像上面這么寫,而是必須放置在子組件的根標簽中。

<div id="app">  <button @click="toshow">點擊讓子組件顯示</button>  <children>  <span slot="first">【12345】</span>  <!--上面這行不會顯示-->  </children>  
</div>  
<script>  var vm = new Vue({  el: '#app',  methods: {  toshow: function () {  this.$children[0].tohidden = true;  }  },  components: {  children: {    //這個無返回值,不會繼續派發  template: "<div v-if='tohidden' @click='tohide'>這里是子組件</div>",  data: function () {  return {  tohidden: true  }  },  methods: {  tohide: function () {  this.tohidden = !this.tohidden;  }  }  }  }  });  
</script>  

說明:

點擊子組件會讓子組件消失;

點擊父組件的按鈕,通過更改子組件的tohidden屬性,讓子組件重新顯示。

子組件的指令綁定在子組件的模板之中(如此才能調用);

轉載于:https://my.oschina.net/bluefrankey/blog/1928806

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/282415.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/282415.shtml
英文地址,請注明出處:http://en.pswp.cn/news/282415.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

turtle庫基礎練習

畫一組同切圓 import turtleturtle.shape(turtle)turtle.circle(10) turtle.circle(20) turtle.circle(30) turtle.circle(40) turtle.circle(50) turtle.circle(60) turtle.circle(70) turtle.circle(80)turtle.hideturtle() turtle.done() 畫一組同心圓 import turtleturtle.…

檢查你的項目的引用包依賴關系

2019獨角獸企業重金招聘Python工程師標準>>> 隨著著開發的進展,你的項目越來越大,引用的第三方包越來越多,但如何查看都依賴了哪些包,甚至傳遞依賴又是怎樣? 首先解決這個問題的前提,你的項目需要是maven項目,然后可以做如下設置: 選中項目&#xff0c;右鍵->ru…

git 項目操作

1 創建本地倉庫,克隆遠程項目代碼到本地倉庫2. 當我們在本地寫了一些代碼之后 , 查看本地倉庫狀態3. 提交改變到待提交區 git add .4. 提交代碼到待推送區 git commit -m "新建項目kuman"5. 將本地代碼推送到遠程代碼倉庫 git push origin master:nanle 注: 將本地m…

(二)SpringBoot功能

web開發 spring boot web開發非常的簡單&#xff0c;其中包括常用的json輸出、filters、property、log等 json 接口開發 在以前的spring 開發的時候需要我們提供json接口的時候需要做那些配置呢 就這樣我們會經常由于配置錯誤&#xff0c;導致406錯誤等等&#xff0c;spring bo…

----斐波那契數列---eval函數----類遞歸思想 棧 進出 思想

------------ 斐波那契 數列 ---------------【1&#xff0c;1,2,3,5,8,13,21,34&#xff0c;...】 1 列表方法實現 # l[1,1] # # # while len(l)<20: # # l.append(l[-1]l[-2]) # # print(l) # # while len(l)!4: # l.append(l[-1]l[-2]) # print(l) # 2 …

【招聘(上海)】 .NET 后端工程師

蟲蟲拜拜&#xff08;https://www.byepest.com/&#xff09;面向城市家庭、連鎖餐飲、醫療機構等提供高品質的蟲害防治業務&#xff0c;已經拓展到了7個城市&#xff0c;2022年前計劃進入22個城市。平臺實現盈利&#xff0c;并且具有獨特的競爭力&#xff0c;已經獲得德國拜耳公…

HybridTime - Accessible Global Consistency with High Clock Uncertainty

Amazon’s Dynamo [9] and Facebook’s Cassandra [13], relax the consistency model&#xff0c;and offer only eventual consistency. Others such as HBase [1] and BigTable [4] offer strong consistency only for operations touching a single partition, but not acr…

公司目前實行的git團隊協作方案

1. git init 新建本地倉庫2. git clone 項目地址 獲取遠程master代碼3. 在本地master代碼上進行開發, 并將修改提交到待推送區4. 開發完, 在本地master分支基礎上創建ready分支5. 在本地ready分支上(本地測試分支), 拉取并合并遠程nanle分支最新代碼(遠程測試分支)6. 將本地re…

bzoj3122 [Sdoi2013]隨機數生成器(bsgs+擴歐+數列)

Description Input 輸入含有多組數據&#xff0c;第一行一個正整數T&#xff0c;表示這個測試點內的數據組數。 接下來T行&#xff0c;每行有五個整數p&#xff0c;a&#xff0c;b&#xff0c;X1&#xff0c;t&#xff0c;表示一組數據。保證X1和t都是合法的頁碼。 注意&…

邊寫 Javascript 代碼邊玩游戲 – WarriorJS

在 github 上看到這個有趣的項目 – WarriorJS &#xff0c;項目的內容寫著 – 令人興奮的程序設計和人工智慧游戲&#xff0c;Ok 我坦白我是看到人工智慧被這個專案所吸引&#xff0c;但是玩了兩個關卡&#xff0c;還是不知道這個游戲跟人工智慧有什么關系&#xff0c;不過這個…

挑選合適自己的一門編程語言

2019獨角獸企業重金招聘Python工程師標準>>> 導讀想學編程的原因有很多&#xff0c;你也許是想要做一個程序&#xff0c;又或者你只是想投身于這個行業&#xff0c;所以&#xff0c;在選擇你的第一門編程語言之前&#xff0c;問問你自己&#xff1a;你想要在哪里運行…

css 實現章節名稱不換行,多余部分用 ... 代替

修改之前:修改之后: 代碼: <p style "white-space: nowrap;text-overflow: ellipsis;overflow: hidden;"><? $d[name] ?></p> <i><? $d[pen_name] ?></i> <i><?phpforeach ($d[tags] as $t) {echo $t[tag_name];…

.NET 反向代理-YARP 部署Https(SSL)

相關文章&#xff1a;.NET 反向代理-YARP.NET 反向代理-YARP 根據域名轉發分享一個基于Abp 和Yarp 開發的API網關項目使用 Yarp 做網關YARP&#xff08;Yet Another Reverse Proxy&#xff09;是使用 .NET 構建的高度可定制的反向代理C# 開源一個基于 yarp 的 API 網關 Demo&am…

shell腳本--cut命令

bash&shell系列文章&#xff1a;http://www.cnblogs.com/f-ck-need-u/p/7048359.html 1.1 選項說明 cut命令將行按指定的分隔符分割成多列&#xff0c;它的弱點在于不好處理多個分隔符重復的情況&#xff0c;因此經常結合tr的壓縮功能。 -b&#xff1a;按字節篩選&#xff…

12C RAC for ASM添加磁盤步驟

RHEL 7.2使用EMC Powerpath擴容2T磁盤空間&#xff0c;需要添加至以用12C RAC for ASM系統中。下面是具體步驟&#xff0c;主機人員告知擴容別名為data_center_16、data_center_17 1&#xff1a;linux 7 系統下添加映射存儲LUN(無需重啟)1>查看機器HBA卡信息--兩個節點機器都…

Windows 下 Redis 的下載和安裝

一 安裝redis 1. 下載redis https://github.com/MicrosoftArchive/redis/releases 注: 如果上面網址下載不了, 就到這里下載 https://download.csdn.net/download/m_nanle_xiaobudiu/104370342. 解壓壓縮文件夾3. 運行redis服務端到此 , redis已經可以正常使用了,但是為了方便…

什么是行內塊元素?

2019獨角獸企業重金招聘Python工程師標準>>> 我們都知道行內元素和塊級元素&#xff0c;在實際開發中&#xff0c;經常會聽到行內塊元素&#xff0c;那么什么是行內塊元素呢&#xff1f; 行內塊元素實際就是把塊元素以行的形式展現,保留了塊元素可以設置的對應CSS屬…

WPF-08 控件模板

模板是描述控件外觀&#xff0c;WPF中每個控件都有一個默認的模板&#xff0c;你可以通過定義模板來重寫控件可視化外觀和行為&#xff0c;WPF中有兩種常用的模板Control Template和Data TemplateControl Template控件模板定義了控件的可視化外觀&#xff0c;所有的UI控件都有自…

玄學搜索\隨稽化

正解又不會寫&#xff0c;又懶得去想 只好每次考試大大暴力&#xff0c;維持一下生活了 ----------------------- P1337 [JSOI2004]平衡點 / 吊打XXX 題目描述 有n個重物&#xff0c;每個重物系在一條足夠長的繩子上。每條繩子自上而下穿過桌面上的洞&#xff0c;然后系在一起。…

第0次作業

問題1:你為什么選擇計算機專業&#xff1f;你認為你的條件如何&#xff1f; 答:我平時比較喜歡研究一些自己認為神秘的東西&#xff0c;我認為計算機就是這樣的神秘東西&#xff01;所以我選擇這個專業&#xff01;我認為我自己可以學會計算機這個專業&#xff01;我對自己有信…