首頁 > web前端 > Vue.js > 了解Vue中的插槽

了解Vue中的插槽

青灯夜游
發布: 2020-10-14 17:41:45
轉載
2448 人瀏覽過

了解Vue中的插槽

Vue插槽,是學習vue中必不可少的一節,當初剛接觸vue的時候,對這些掌握的一知半解,特別是作用域插槽一直沒明白。

後面越來越發現插槽的好用。

分享一下插槽的一些知識吧。

一、插槽內容

一句話:插槽內可以是任意內容。

先看一下下面的程式碼:宣告一個child-component元件,

如果現在我想在內放置一些內容,結果會是怎樣?

<div id="app">
    <child-component></child-component>

</div>
<script>
    Vue.component(&#39;child-component&#39;,{
        template:`
            <div>Hello,World!</div>
        `
    })
    let vm = new Vue({
        el:&#39;#app&#39;,
        data:{

        }
    })
</script>
登入後複製
<child-component>你好</child-component>
登入後複製

 輸出內容還是在元件中的內容,在 內寫的內容沒起作用。

了解Vue中的插槽

我們現在為元件增加一個插槽

我們在內寫的"你好"起作用了! ! !

Vue.component(&#39;child-component&#39;,{
        template:`
            <div>
            Hello,World!
            <slot></slot>
            </div>
        `
    })
登入後複製

了解Vue中的插槽

到現在,我們知道了什麼是插槽: 

插槽就是Vue實現的一套內容分發的API,將元素作為承載分發內容的出口。

這句話的意思是,沒有插槽的情況下在組件標籤內些一些內容是不起任何作用的,當我在組件中聲明了slot元素後,在組件元素內寫的內容就會跑到它這裡了!

二、具名插槽

具名插槽,就是給這個插槽取個名字

在元件中,我給插槽起個名字,一個名字叫"girl",一個名字叫"boy",還有一個不起名字。

然後再內,slot屬性對應的內容都會和元件中name一一對應。

而沒有名字的,就是預設插槽! !

<div id="app">
    <child-component>
        <template slot="girl">
            漂亮、美丽、购物、逛街
        </template>
        <template slot="boy">
            帅气、才实
        </template>
        <div>
            我是一类人,
            我是默认的插槽
        </div>
    </child-component>
</div>
<script>
    Vue.component(&#39;child-component&#39;,{
        template:`
            <div>
            <h4>这个世界不仅有男人和女人</h4>

            <slot name="girl"></slot>

            <div style="height:1px;background-color:red;"></div>

            <slot name="boy"></slot>

            <div style="height:1px;background-color:red;"></div>

            <slot></slot>
            </div>
        `
    })
    let vm = new Vue({
        el:&#39;#app&#39;,
        data:{

        }
    })
</script>
登入後複製

3、作用域插槽

之前一直沒搞懂作用域插槽到底是什麼! ! !

說白了就是我在元件上的屬性,可以在元件元素內使用!

先看一個最簡單的例子! !

我們給元素上定義一個屬性say(隨便定義的!),接下來在使用組件child,然後在template元素上添加屬性slot-scope! !隨便取個名字a

我們把a印一個發現是 {"say" : "你好"},也就是slot上面的屬性和值組成的鍵值對! ! !

這就是作用域插槽!

我可以把元件上的屬性/值,在元件元素上使用! !

<div id="app">
    <child>
        <template slot-scope="a">
      <!-- {"say":"你好"} -->

            {{a}}
        </template>
    </child>
</div>
<script>
    Vue.component(&#39;child&#39;,{
        template:`
            <div>
                <slot say="你好"></slot>
            </div>
        `
    })

    let vm = new Vue({
        el:&#39;#app&#39;,
        data:{

        }
    })
</script>
登入後複製

再看一下下面的範例:

<div id="app">
    <child :lists="nameList">
        <template slot-scope="a">
            {{a}}
        </template>
    </child>
</div>
<script>
    Vue.component(&#39;child&#39;,{
        props:[&#39;lists&#39;],
        template:`
            <div>
                <ul>
                    <li v-for="list in lists">
                        <slot :bbbbb="list"></slot>
                    </li>
                </ul>
            </div>
        `
    })

    let vm = new Vue({
        el:&#39;#app&#39;,
        data:{
            nameList:[
            {id:1,name:&#39;孙悟空&#39;},
            {id:2,name:&#39;猪八戒&#39;},
            {id:3,name:&#39;沙和尚&#39;},
            {id:4,name:&#39;唐僧&#39;},
            {id:5,name:&#39;小白龙&#39;},
            ]
        }
    })
</script>
登入後複製

看一下輸出結果

了解Vue中的插槽

相關推薦:

2020年前端vue面試題大匯總(附答案)

#vue教學推薦:2020最新的5個vue.js影片教學精選

更多程式相關知識,請造訪:程式設計入門! !

以上是了解Vue中的插槽的詳細內容。更多資訊請關注PHP中文網其他相關文章!

相關標籤:
來源:cnblogs.com
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板