欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

詳解Vue 匿名、具名和作用域插槽的使用方法

 更新時間:2019年04月22日 10:00:51   作者:JS菌  
這篇文章主要介紹了Vue 匿名、具名和作用域插槽的使用方法,非常不錯,具有一定的參考借鑒價值,需要的朋友可以參考下

Vue 中的插槽在開發(fā)組件的過程中其實是非常重要并且好用的。Vue 的插槽也沒有說很難使用,這篇文章簡明扼要的介紹了三種插槽的用法。

匿名插槽

子組件定義 slot 插槽,但并未具名,因此也可以說是默認插槽。只要在父元素中插入的內(nèi)容,默認加入到這個插槽中去。 😵

<template>
 <div>
 hello <slot>陌生人</slot>
 </div>
</template>

這里定義了一個默認插槽,只要往里頭丟東西,就會被加入到這個插槽里面

slot 元素里面可以加入一系列后備內(nèi)容,一旦父元素沒有插入任何信息,那么就會渲染后備內(nèi)容。

<my-comp>
 oli
</my-comp>

如在父組件中使用這個子組件,并插入 oli 字符串,效果如下:

具名插槽

具名插槽可以出現(xiàn)在不同的地方,不限制出現(xiàn)的次數(shù)。只要匹配了 name 那么這些內(nèi)容就會被插入到這個 name 的插槽中去。

<template>
 <div>
 <slot name="nav"></slot>
 <br/>
 <slot name="content"></slot>
 <br/>
 <slot name="footer"></slot>
 </div>
</template>

比如上述代碼定義了三個具名插槽。在父組件中即可使用 slot 屬性插入到對應的插槽中:

<template>
 <div>
 <my-comp>
 <template slot="nav">navigator</template>
 <template slot="footer">footer</template>
 <template slot="content">content</template>
 </my-comp>
 </div>
</template>

另外,順序并不重要,content 在 footer 下方但依然能夠按照 slot 定義的順序渲染:

作用域插槽

通常情況下普通的插槽是父組件使用插槽過程中傳入東西決定了插槽的內(nèi)容。但有時我們需要獲取到子組件提供的一些數(shù)據(jù),那么作用域插槽就排上用場了。 🤓

在子組件中創(chuàng)建 slot 并通過 v-bind 綁定數(shù)據(jù) prop 的形式傳入數(shù)據(jù):

<slot :data="data"></slot>

在組件 data 中創(chuàng)建數(shù)據(jù):

export default {
 name: 'MyComp',
 data () {
 return {
 data: { // 內(nèi)部狀態(tài)
 username: 'oli'
 }
 }
 }
}

這樣就可以在插槽中訪問到子元素的數(shù)據(jù)了:

<template v-slot:default="user">{{user.data.username}}</template>

也可以不書寫 default 關(guān)鍵字,默認就是假定對應默認插槽

<template v-slot="user">{{user.data.username}}</template>

使用 v-slot 綁定一個命名空間 user,這樣就可以通過 user 對象引用到子組件中傳入的數(shù)據(jù)了

與具名插槽配合時,需要明確書寫對應的命名空間:

<template #:one="user">{{user.data.username}}</template>
<template #:another="user">{{user.data.username}}</template>
# 代表 v-slot 的縮寫,縮寫在有參數(shù)的情況下才會生效

動態(tài)插槽名

另外,2.6 版本的 vue 還加入了動態(tài)插槽名的功能,用來動態(tài)的定義插槽名稱:

<template #:[dynamicSlotName]></template>

https://cn.vuejs.org/v2/guide...

PS:Vue作用域插槽使用實例詳解

這次給大家?guī)鞻ue作用域插槽使用詳解,Vue作用域插槽使用的注意事項有哪些,下面就是實戰(zhàn)案例,一起來看一下。

舉個例子,比如我寫了一個可以實現(xiàn)條紋相間的列表組件,發(fā)布后,使用者可以自定義每一行的內(nèi)容或樣式(普通的slot就可以完成這個工作)。而作用域插槽的關(guān)鍵之處就在于,父組件能接收來自子組件的slot傳遞過來的參數(shù),具體看案例和注釋。

<!DOCTYPE html>
 <htmllang="en">
 <head>
  <metacharset="UTF-8">
  <title>Vue作用域插槽</title>
  <scriptsrc="https://cdn.bootcss.com/vue/2.3.4/vue.js"></script>
 </head>
 <body>
  <pid="app2">
   <my-stripe-list:items="users"odd-bgcolor="#D3DCE6"even-bgcolor="#E5E9F2">
    <!-- props對象接收來自子組件slot的$index參數(shù) -->
    <templateslot="cont"scope="props">
     <span>{{users[props.$index].id}}</span>
     <span>{{users[props.$index].name}}</span>
     <span>{{users[props.$index].age}}</span>
     <!-- 這里可以自定[編輯][刪除]按鈕的鏈接和樣式 -->
     <a:href="'#edit/id/'+users[props.$index].id"rel="external nofollow">編輯</a>
     <a:href="'#del/id/'+users[props.$index].id"rel="external nofollow">刪除</a>
    </template>
   </my-stripe-list>
  </p>
  <script>
   Vue.component('my-stripe-list', {
    /*slot的$index可以傳遞到父組件中*/
    template: `
     <p>
      <pv-for="(item, index) in items"style="line-height:2.2;":style="index % 2 === 0 ? 'background:'+oddBgcolor : 'background:'+evenBgcolor">
       <slotname="cont":$index="index"></slot>
      </p>
     </p>
    `,
    props: {
     items: Array,
     oddBgcolor: String,
     evenBgcolor: String
    }
   });
   new Vue({
    el: '#app2',
    data: {
     users: [
      {id: 1, name: '張三', age: 20},
      {id: 2, name: '李四', age: 22},
      {id: 3, name: '王五', age: 27},
      {id: 4, name: '張龍', age: 27},
      {id: 5, name: '趙虎', age: 27}
     ]
    }
   });
  </script>
 </body>
</html>

總結(jié)

以上所述是小編給大家介紹的Vue 匿名、具名和作用域插槽的使用方法,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
如果你覺得本文對你有幫助,歡迎轉(zhuǎn)載,煩請注明出處,謝謝!

相關(guān)文章

  • vue登錄路由權(quán)限管理的項目實踐

    vue登錄路由權(quán)限管理的項目實踐

    在開發(fā)Web應用程序時,常常需要進行登錄驗證和權(quán)限管理,本文主要介紹了vue登錄路由權(quán)限管理的項目實踐,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2023-04-04
  • vue使用swiper插件實現(xiàn)輪播圖的示例

    vue使用swiper插件實現(xiàn)輪播圖的示例

    這篇文章主要介紹了vue使用swiper插件實現(xiàn)輪播圖的示例,幫助大家更好的理解和學習使用vue框架,感興趣的朋友可以了解下
    2021-05-05
  • vue3實現(xiàn)淘寶放大鏡效果的示例代碼

    vue3實現(xiàn)淘寶放大鏡效果的示例代碼

    放大鏡效果在很多購物網(wǎng)站都可以看到,本文主要介紹了vue3實現(xiàn)淘寶放大鏡效果的示例代碼,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2022-06-06
  • Vue動態(tài)數(shù)據(jù)實現(xiàn)?el-select?多級聯(lián)動、數(shù)據(jù)回顯方式

    Vue動態(tài)數(shù)據(jù)實現(xiàn)?el-select?多級聯(lián)動、數(shù)據(jù)回顯方式

    這篇文章主要介紹了Vue動態(tài)數(shù)據(jù)實現(xiàn)?el-select?多級聯(lián)動、數(shù)據(jù)回顯方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-07-07
  • 使用Vue.js和Element-UI做一個簡單登錄頁面的實例

    使用Vue.js和Element-UI做一個簡單登錄頁面的實例

    下面小編就為大家分享一篇使用Vue.js和Element-UI做一個簡單登錄頁面的實例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-02-02
  • element-vue實現(xiàn)網(wǎng)頁鎖屏功能(示例代碼)

    element-vue實現(xiàn)網(wǎng)頁鎖屏功能(示例代碼)

    這篇文章主要介紹了element-vue實現(xiàn)網(wǎng)頁鎖屏功能,本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友參考下吧
    2023-11-11
  • 關(guān)于element-ui表單中限制輸入純數(shù)字的解決方式

    關(guān)于element-ui表單中限制輸入純數(shù)字的解決方式

    這篇文章主要介紹了關(guān)于element-ui表單中限制輸入純數(shù)字的解決方式,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-09-09
  • 如何抽象一個Vue公共組件

    如何抽象一個Vue公共組件

    這篇文章主要介紹了如何抽象一個Vue公共組件,以一個數(shù)字鍵盤組件為例,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-10-10
  • Vue中l(wèi)ocalStorage的用法和監(jiān)聽localStorage值的變化

    Vue中l(wèi)ocalStorage的用法和監(jiān)聽localStorage值的變化

    這篇文章主要介紹了Vue中l(wèi)ocalStorage的用法和監(jiān)聽localStorage值的變化,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2023-04-04
  • vue實現(xiàn)動態(tài)路由的方法及路由原理解析

    vue實現(xiàn)動態(tài)路由的方法及路由原理解析

    這篇文章主要介紹了路由原理及vue實現(xiàn)動態(tài)路由,Vue Router 提供了豐富的 API,可以輕松地實現(xiàn)路由功能,并支持路由參數(shù)、查詢參數(shù)、命名路由、嵌套路由等功能,可以滿足不同應用程序的需求,需要的朋友可以參考下
    2023-06-06

最新評論