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

vue 使用插槽分發(fā)內(nèi)容操作示例【單個插槽、具名插槽、作用域插槽】

 更新時間:2020年03月06日 12:14:21   作者:程序媛-jjl  
這篇文章主要介紹了vue 使用插槽分發(fā)內(nèi)容操作,結(jié)合實例形式總結(jié)分析了vue.js使用單個插槽、具名插槽、作用域插槽相關(guān)操作技巧與注意事項,需要的朋友可以參考下

本文實例講述了vue 使用插槽分發(fā)內(nèi)容操作。分享給大家供大家參考,具體如下:

單個插槽

除非子組件模板包含至少一個 <slot> 插口,否則父組件的內(nèi)容將會被丟棄。當(dāng)子組件模板只有一個沒有屬性的插槽時,父組件傳入的整個內(nèi)容片段將插入到插槽所在的 DOM 位置,并替換掉插槽標簽本身。

最初在 <slot> 標簽中的任何內(nèi)容都被視為備用內(nèi)容。備用內(nèi)容在子組件的作用域內(nèi)編譯,并且只有在宿主元素為空,且沒有要插入的內(nèi)容時才顯示備用內(nèi)容。

例:

<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>Vue 測試實例 - 單個插槽</title>
<script src="https://cdn.bootcss.com/vue/2.2.2/vue.min.js"></script>
</head>
<body>
 
<div id="example">
  <div>
 <h1>我是父組件的標題</h1>
 <my-component>
  <p>這是一些初始內(nèi)容</p>
  <p>這是更多的初始內(nèi)容</p>
 </my-component>
</div>
</div>
 
 
var childNode = {
  //當(dāng)沒有<slot>時,父組件的其他內(nèi)容不會顯示,當(dāng)有<slot>時,要是父組件中的內(nèi)容不為空,<slot>
  //中的內(nèi)容就不會顯示
 template: `
 <div>
 <h2>我是子組件的標題</h2>
 <slot>
  只有在沒有要分發(fā)的內(nèi)容時才會顯示。
 </slot>
</div>
 `,
};
// 創(chuàng)建根實例
new Vue({
 el: '#example',
 components: {
 'my-component': childNode
 }
})
</script>
</body>
</html>

具名插槽

<slot> 元素可以用一個特殊的特性 name 來進一步配置如何分發(fā)內(nèi)容。多個插槽可以有不同的名字。具名插槽將匹配內(nèi)容片段中有對應(yīng) slot 特性的元素。

仍然可以有一個匿名插槽,它是默認插槽,作為找不到匹配的內(nèi)容片段的備用插槽。如果沒有默認插槽,這些找不到匹配的內(nèi)容片段將被拋棄。

<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>Vue 測試實例 - 具名插槽</title>
<script src="https://cdn.bootcss.com/vue/2.2.2/vue.min.js"></script>
</head>
<body>
 
<div id="example">
 <app-layout>
 <h1 slot="header">這里可能是一個頁面標題</h1>
 
 <p>主要內(nèi)容的一個段落。</p>
 <p>另一個主要段落。</p>
 
 <p slot="footer">這里有一些聯(lián)系信息</p>
</app-layout>
</div>
 <script>
 Vue.component('app-layout',{
 template:'<div class="container">'+
 '<header>'+
  '<slot name="header"></slot>'+
 '</header>'+
 '<main>'+
  '<slot></slot>'+
 '</main>'+
 '<footer>'+
  '<slot name="footer"></slot>'+
 '</footer>'+
'</div>'
 })
 
// 創(chuàng)建根實例
new Vue({
 el: '#example',
 
})
</script>
</body>
</html>

作用域插槽

作用域插槽是一種特殊類型的插槽,用作一個 (能被傳遞數(shù)據(jù)的) 可重用模板,來代替已經(jīng)渲染好的元素。

在子組件中,只需將數(shù)據(jù)傳遞到插槽,就像你將 prop 傳遞給組件一樣:

<div class="child">
 <slot text="hello from child"></slot>
</div>

在父級中,具有特殊特性 slot-scope 的 <template> 元素必須存在,表示它是作用域插槽的模板。slot-scope 的值將被用作一個臨時變量名,此變量接收從子組件傳遞過來的 prop 對象:

在 2.5.0+,slot-scope 能被用在任意元素或組件中而不再局限于 <template>。

<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>Vue 測試實例 - 作用域插槽</title>
<script src="https://cdn.bootcss.com/vue/2.2.2/vue.min.js"></script>
</head>
<body>
 
<div id="example">
   <parent-com></parent-com>
</div>
  <script>
  Vue.component('child-com',{
    template:'' +
    '<ul>' +
    '  <slot name="child-ul" v-for="item in animal" v-bind:text="item.name"></slot>' +
    '</ul>',
    data:function(){
      return {
        animal:[
          {name:'大象'},
          {name:'小狗'},
          {name:'小貓'},
          {name:'老虎'}
        ]
      }
    }
  });
  //父組件
  // 在父組件的模板里,使用一個Vue自帶的特殊組件<template> ,
  // 并在該組件上使用scope屬性,值是一個臨時的變量,存著的是由子組件傳過來的
  // prop對象,在下面的例子中我把他命名為props。
  // 獲得由子傳過來的prop對象。這時候,父組件就可以訪問子組件在自定義屬性上暴露的數(shù)據(jù)了。
  Vue.component('parent-com',{
    template:'' +
    '<div class="container">' +
    '<p>動物列表</p>' +
    '<child-com>' +
    '  <template scope="props" slot="child-ul">' +
    '    <li class="child-ul">{{ props.text }}</li>' +
    '  </template>' +
    '</child-com>' +
    '</div>'
  });
 
// 創(chuàng)建根實例
new Vue({
 el: '#example',
 
})
</script>
</body>
</html>

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

相關(guān)文章

  • vue 使某個組件不被 keep-alive 緩存的方法

    vue 使某個組件不被 keep-alive 緩存的方法

    今天小編就為大家分享一篇vue 使某個組件不被 keep-alive 緩存的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-09-09
  • Vue draggable實現(xiàn)從左到右拖拽功能

    Vue draggable實現(xiàn)從左到右拖拽功能

    這篇文章主要為大家詳細介紹了Vue draggable實現(xiàn)從左到右拖拽功能,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-04-04
  • vue 中常見的時間格式轉(zhuǎn)換

    vue 中常見的時間格式轉(zhuǎn)換

    這篇文章主要介紹了vue 中常見的時間格式轉(zhuǎn)換,需要的朋友可以參考下
    2022-05-05
  • 基于Vue設(shè)計實現(xiàn)一個彈幕組件

    基于Vue設(shè)計實現(xiàn)一個彈幕組件

    這篇文章主要給大家分享一個開發(fā)中常見的需求,接下來將為大家詳細介紹彈幕的實現(xiàn)以及設(shè)計思路一步一步描述出來,希望大家能夠喜歡
    2023-06-06
  • vue的hash值原理也是table切換實例代碼

    vue的hash值原理也是table切換實例代碼

    這篇文章主要介紹了vue的hash值原理也是table切換,本文通過實例代碼給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-12-12
  • 聊聊Vue.js的template編譯的問題

    聊聊Vue.js的template編譯的問題

    這篇文章主要介紹了聊聊Vue.js的template編譯的問題,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-10-10
  • vue項目如何引入公共頭部底部

    vue項目如何引入公共頭部底部

    這篇文章主要介紹了vue項目如何引入公共頭部底部問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-01-01
  • ElementPlus 中el-select自定義指令實現(xiàn)觸底加載請求options數(shù)據(jù)的方法

    ElementPlus 中el-select自定義指令實現(xiàn)觸底加載請求options數(shù)據(jù)的方法

    觸底時,繼續(xù)向后端發(fā)請求獲取下一頁的數(shù)據(jù),請求回來的數(shù)據(jù)合并給options,這篇文章主要介紹了ElementPlus 中el-select自定義指令實現(xiàn)觸底加載請求options數(shù)據(jù)的操作方法,需要的朋友可以參考下
    2024-08-08
  • vue日常開發(fā)基礎(chǔ)Axios網(wǎng)絡(luò)庫封裝

    vue日常開發(fā)基礎(chǔ)Axios網(wǎng)絡(luò)庫封裝

    這篇文章主要為大家介紹了vue日常開發(fā)基礎(chǔ)Axios網(wǎng)絡(luò)庫封裝示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-08-08
  • Vue使用Echarts圖表多次初始化報錯問題的解決方法

    Vue使用Echarts圖表多次初始化報錯問題的解決方法

    最近在學(xué)習(xí)Vue的時候,正好學(xué)到了引入echarts圖表做數(shù)據(jù)統(tǒng)計的內(nèi)容,所以下面這篇文章主要給大家介紹了關(guān)于Vue使用Echarts圖表多次初始化報錯問題的解決方法,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下
    2022-05-05

最新評論