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

Vue插槽原理與用法詳解

 更新時間:2019年03月05日 10:58:00   作者:deniro_li  
這篇文章主要介紹了Vue插槽原理與用法,結(jié)合實例形式詳細(xì)分析了vue.js插槽內(nèi)容、具名插槽、作用域插槽等相關(guān)原理與使用方法,需要的朋友可以參考下

本文實例講述了Vue插槽原理與用法。分享給大家供大家參考,具體如下:

1 插槽內(nèi)容

Vue 實現(xiàn)了一套內(nèi)容分發(fā)的 API,這套 API 基于當(dāng)前的 Web Components 規(guī)范草案,將 <slot> 元素作為承載分發(fā)內(nèi)容的出口。

它允許你像這樣合成組件:

<div id="app1">
  <navigation-link url="/profile">
    Your Profile
  </navigation-link>
</div>

然后你在 <navigation-link> 的模板中可能會寫為:

Vue.component('navigation-link', {
    template: `
      <a
        v-bind:href="url" rel="external nofollow" 
        class="nav-link"
      >
      <slot></slot>
      </a>
    `
  });

當(dāng)組件渲染的時候,這個 <slot> 元素將會被替換為“Your Profile”。

插槽內(nèi)可以包含任何模板代碼,包括 HTML:

<navigation-link url="/profile">
 <!-- 添加一個 Font Awesome 圖標(biāo) -->
 <span class="fa fa-user"></span>
 Your Profile
</navigation-link>

甚至其它的組件:

<navigation-link url="/profile">
 <!-- 添加一個圖標(biāo)的組件 -->
 <font-awesome-icon name="user"></font-awesome-icon>
 Your Profile
</navigation-link>

如果 <navigation-link> 沒有包含一個 <slot> 元素,則任何傳入它的內(nèi)容都會被拋棄。

2 具名插槽

有些時候我們需要多個插槽。例如,一個假設(shè)的 <base-layout> 組件多模板如下:

<div class="container">
 <header>
  <!-- 我們希望把頁頭放這里 -->
 </header>
 <main>
  <!-- 我們希望把主要內(nèi)容放這里 -->
 </main>
 <footer>
  <!-- 我們希望把頁腳放這里 -->
 </footer>
</div>

對于這樣的情況,<slot> 元素有一個特殊的特性:name。這個特性可以用來定義額外的插槽:

<div class="container">
 <header>
  <slot name="header"></slot>
 </header>
 <main>
  <slot></slot>
 </main>
 <footer>
  <slot name="footer"></slot>
 </footer>
</div>

在向具名插槽提供內(nèi)容的時候,我們可以在一個父組件的 <template> 元素上使用 slot 特性:

<base-layout>
 <template slot="header">
  <h1>Here might be a page title</h1>
 </template>
 <p>A paragraph for the main content.</p>
 <p>And another one.</p>
 <template slot="footer">
  <p>Here's some contact info</p>
 </template>
</base-layout>

另一種 slot 特性的用法是直接用在一個普通的元素上:

<base-layout>
 <h1 slot="header">Here might be a page title</h1>
 <p>A paragraph for the main content.</p>
 <p>And another one.</p>
 <p slot="footer">Here's some contact info</p>
</base-layout>

我們還是可以保留一個未命名插槽,這個插槽是默認(rèn)插槽,也就是說它會作為所有未匹配到插槽的內(nèi)容的統(tǒng)一出口。上述兩個示例渲染出來的 HTML 都將會是:

<div class="container">
 <header>
  <h1>Here might be a page title</h1>
 </header>
 <main>
  <p>A paragraph for the main content.</p>
  <p>And another one.</p>
 </main>
 <footer>
  <p>Here's some contact info</p>
 </footer>
</div>

3 默認(rèn)插槽的內(nèi)容

有的時候為插槽提供默認(rèn)的內(nèi)容是很有用的。例如,一個 <submit-button> 組件可能希望這個按鈕的默認(rèn)內(nèi)容是“Submit”,但是同時允許用戶覆寫為“Save”、“Upload”或別的內(nèi)容。

你可以在 <slot> 標(biāo)簽內(nèi)部指定默認(rèn)的內(nèi)容來做到這一點。

<button type="submit">
 <slot>Submit</slot>
</button>

如果父組件為這個插槽提供了內(nèi)容,則默認(rèn)的內(nèi)容會被替換掉。

4 編譯作用域

當(dāng)你想在插槽內(nèi)使用數(shù)據(jù)時,例如:

<navigation-link url="/profile">
 Logged in as {{ user.name }}
</navigation-link>

該插槽可以訪問跟這個模板的其它地方相同的實例屬性 (也就是說“作用域”是相同的)。但這個插槽不能訪問 <navigation-link> 的作用域。例如嘗試訪問 url 是不會工作的。牢記一條準(zhǔn)則:

父組件模板的所有東西都會在父級作用域內(nèi)編譯;子組件模板的所有東西都會在子級作用域內(nèi)編譯。

5 作用域插槽

2.1.0+ 新增

有的時候你希望提供的組件帶有一個可從子組件獲取數(shù)據(jù)的可復(fù)用的插槽。例如一個簡單的 <todo-list> 組件的模板可能包含了如下代碼:

Vue.component('todo-list',{
    template:`
    <ul>
      <li
        v-for="todo in todos"
        v-bind:key="todo.id">
        {{ todo.text }}
      </li>
    </ul>
    `
  });

但是在我們應(yīng)用的某些部分,我們希望每個獨立的待辦項渲染出和 todo.text 不太一樣的東西。這也是作用域插槽的用武之地。

為了讓這個特性成為可能,你需要做的全部事情就是將待辦項內(nèi)容包裹在一個 <slot> 元素上,然后將所有和其上下文相關(guān)的數(shù)據(jù)傳遞給這個插槽:在這個例子中,這個數(shù)據(jù)是 todo 對象:

<ul>
 <li
  v-for="todo in todos"
  v-bind:key="todo.id"
 >
  <!-- 我們?yōu)槊總€ todo 準(zhǔn)備了一個插槽,-->
  <!-- 將 `todo` 對象作為一個插槽的 prop 傳入。-->
  <slot v-bind:todo="todo">
   <!-- 回退的內(nèi)容 -->
   {{ todo.text }}
  </slot>
 </li>
</ul>

現(xiàn)在當(dāng)我們使用 <todo-list> 組件的時候,我們可以選擇為待辦項定義一個不一樣的<template> 作為替代方案,并且可以通過 slot-scope 特性從子組件獲取數(shù)據(jù):

<todo-list v-bind:todos="todos">
  <!--插槽作用域的名字是 slotProps-->
  <template slot-scope="slotProps">
    <!-- 為指定的待辦項定義一個模板-->
    <span v-if="slotProps.todo.isComplete">✓</span>
    {{ slotProps.todo.text }}
  </template>
</todo-list>

在 2.5.0+,slot-scope 不再限制在 <template> 元素上使用,而可以用在插槽內(nèi)的任何元素或組件上。

解構(gòu) slot-scope

如果一個 JavaScript 表達(dá)式在一個函數(shù)定義的參數(shù)位置有效,那么這個表達(dá)式實際上就可以被 slot-scope 接受。也就是說你可以在支持的環(huán)境下 單文件組件或現(xiàn)代瀏覽器),在這些表達(dá)式中使用 ES2015 解構(gòu)語法。例如:

<todo-list v-bind:todos="todos">
 <template slot-scope="{ todo }">
  <span v-if="todo.isComplete">✓</span>
  {{ todo.text }}
 </template>
</todo-list>

這會使作用域插槽變得更干凈一些。

希望本文所述對大家vue.js程序設(shè)計有所幫助。

相關(guān)文章

  • vue實現(xiàn)簡單的購物車小案例

    vue實現(xiàn)簡單的購物車小案例

    這篇文章主要為大家詳細(xì)介紹了vue實現(xiàn)簡單的購物車小案例,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-07-07
  • Vue 詳解mixins混入用法大全

    Vue 詳解mixins混入用法大全

    如果我們在每個組件中去重復(fù)定義這些屬性和方法會使得項目出現(xiàn)代碼冗余并提高了維護難度,針對這種情況官方提供了Mixins特性,這時使用Vue mixins混入有很大好處,下面就介紹下Vue mixins混入使用方法,需要的朋友參考下吧
    2021-08-08
  • vue+echarts定時重新繪制以達(dá)到刷新的動效問題

    vue+echarts定時重新繪制以達(dá)到刷新的動效問題

    這篇文章主要介紹了vue+echarts定時重新繪制以達(dá)到刷新的動效問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-06-06
  • Vue SPA 初次進入加載動畫實現(xiàn)代碼

    Vue SPA 初次進入加載動畫實現(xiàn)代碼

    今天小編就為大家分享一篇Vue SPA 初次進入加載動畫實現(xiàn)代碼,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-11-11
  • Vue3之getCurrentInstance與ts結(jié)合使用的方式

    Vue3之getCurrentInstance與ts結(jié)合使用的方式

    這篇文章主要介紹了Vue3之getCurrentInstance與ts結(jié)合使用的方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-04-04
  • Vue select 綁定動態(tài)變量的實例講解

    Vue select 綁定動態(tài)變量的實例講解

    這篇文章主要介紹了Vue select 綁定動態(tài)變量的實例講解,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-10-10
  • vue2組件實現(xiàn)懶加載淺析

    vue2組件實現(xiàn)懶加載淺析

    本篇文章主要介紹了vue2組件實現(xiàn)懶加載淺析,運用懶加載則可以將頁面進行劃分,需要的時候加載頁面,可以有效的分擔(dān)首頁所承擔(dān)的加載壓力.
    2017-03-03
  • vue路由結(jié)構(gòu)可設(shè)一層方便動態(tài)添加路由操作

    vue路由結(jié)構(gòu)可設(shè)一層方便動態(tài)添加路由操作

    這篇文章主要介紹了vue路由結(jié)構(gòu)可設(shè)一層方便動態(tài)添加路由操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-08-08
  • vue中關(guān)于redirect(重定向)初學(xué)者的坑

    vue中關(guān)于redirect(重定向)初學(xué)者的坑

    這篇文章主要介紹了vue中關(guān)于redirect(重定向)初學(xué)者的坑,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-08-08
  • 基于Vue實現(xiàn)拖拽效果

    基于Vue實現(xiàn)拖拽效果

    這篇文章主要介紹了基于Vue實現(xiàn)拖拽效果,文中給大家介紹了clientY pageY screenY layerY offsetY的區(qū)別講解,需要的朋友可以參考下
    2018-04-04

最新評論