91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Vue.js中的作用域插槽是什么

發布時間:2021-01-21 10:52:47 來源:億速云 閱讀:174 作者:小新 欄目:編程語言

小編給大家分享一下Vue.js中的作用域插槽是什么,希望大家閱讀完這篇文章之后都有所收獲,下面讓我們一起去探討吧!

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

當你不能很容易地理解某件事時,一個好的方法是試著用它來解決問題。在本文中,我將演示如何使用作用域槽來構建可重用列表組件。

Vue.js中的作用域插槽是什么

基本組成部分

我們要構建的組件叫做my-list,它顯示了很多東西。該特性的特殊之處在于,您可以自定義列表項在每次使用組件時的呈現方式。

讓我們首先處理最簡單的用例,并獲取my-list來呈現一個列表:一個幾何形狀名稱數組和它們的邊數。

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

現在,我們想要使my-list功能足夠多,以呈現任何類型的列表。第二個測試用例將是一個顏色列表,包括一個小樣本來顯示顏色。

為此,我們必須抽象特定于形狀列表的任何數據。由于列表中的項的結構可能不同,我們將為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>

現在讓我們在根實例中創建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中的作用域插槽是什么

表面成分

我們剛剛創建的代碼工作得很好,但是代碼并不好。my-list是按名稱顯示列表的組件。但是我們已經抽象了所有將列表呈現到父列表中的邏輯。組件只是用一些表示標記將列表包裝起來。

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

作用域的插槽

為了實現這一點,我們將使用作用域槽而不是常規槽。作用域插槽允許您將模板傳遞給插槽,而不是傳遞呈現的元素。它被稱為“作用域”槽,因為盡管模板是在父作用域中呈現的,但它可以訪問特定的子數據。

例如,具有作用域插槽的組件子組件可能如下所示。

<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中使用作用域插槽

讓我們將列表數組作為道具傳遞給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>

現在我們得到my-list來迭代這些項。在v-for循環中,item是當前列表項的別名。我們可以創建一個槽,并使用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在沒有參數的情況下使用,這將把整個對象的屬性綁定到元素。這對于作用域插槽非常有用,因為您綁定的對象通常具有任意屬性,現在不需要通過名稱指定這些屬性。

現在我們將返回到根實例,并在my-list的slot中聲明一個模板。首先查看形狀列表,模板必須包含我們為其分配別名形狀的scope屬性。這個別名允許我們訪問限定范圍的道具。在模板內部,我們可以使用與以前完全相同的標記來顯示形狀列表項。

<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>

看完了這篇文章,相信你對“Vue.js中的作用域插槽是什么”有了一定的了解,如果想了解更多相關知識,歡迎關注億速云行業資訊頻道,感謝各位的閱讀!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

松原市| 双江| 新竹县| 贺州市| 靖西县| 雅江县| 阳江市| 沽源县| 常德市| 东台市| 岳池县| 旌德县| 平顶山市| 阿克苏市| 绥化市| 高青县| 高州市| 临湘市| 中江县| 望城县| 子长县| 忻州市| 芮城县| 泸水县| 连州市| 合肥市| 乌拉特中旗| 依安县| 怀仁县| 北碚区| 洮南市| 晋城| 桃江县| 海林市| 庆城县| 吴江市| 沿河| 四平市| 蒙山县| 易门县| 灵石县|