Maison >interface Web >Voir.js >En savoir plus sur les machines à sous dans Vue

En savoir plus sur les machines à sous dans Vue

青灯夜游
青灯夜游avant
2020-10-14 17:41:452459parcourir

En savoir plus sur les machines à sous dans Vue

Le slot Vue est un élément indispensable de l'apprentissage de Vue. Lorsque je suis entré en contact avec Vue, je n'avais qu'une petite compréhension de ceux-ci, en particulier du slot scope.

Plus tard, j'ai trouvé les machines à sous de plus en plus utiles.

Partagez quelques connaissances sur les machines à sous.

1. Contenu du slot

En une phrase : Le slot peut contenir n'importe quel contenu.

Regardez d'abord le code suivant : déclarez un composant de composant enfant,

Si maintenant je veux placer du contenu dans , le résultat Comment ça va se passer ?

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

Le contenu de sortie est toujours le contenu du composant, et le contenu écrit dans

En savoir plus sur les machines à sous dans Vue

Nous ajoutons maintenant un emplacement au composant

Nous sommes dans enfant -Le "Bonjour" écrit en -component> ! !

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

En savoir plus sur les machines à sous dans Vue

Maintenant, nous savons ce qu'est un slot :

Slot est un ensemble d'API de distribution de contenu implémenté par Vue. ; sert de support pour transporter le contenu de distribution.

Ce que cette phrase signifie, c'est que s'il n'y a pas de slot, certains contenus de la balise composant n'auront aucun effet. Lorsque je déclare l'élément slot dans le composant, dans l'élément composant Le contenu écrit. l'intérieur courra vers lui !

2. Slot nommé

Un slot nommé consiste à donner un nom au slot

Dans le composant, je donne un nom au slot Il y a trois noms, un s'appelle « fille », un s'appelle « garçon » et un n'a pas de nom.

Ensuite, dans , le contenu correspondant à l'attribut slot correspondra un à un avec le nom dans le composant.

Celui sans nom est l'emplacement par défaut ! !

<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. Emplacements de portée

Je n'avais jamais compris ce qu'est un emplacement de portée avant ! ! !

Pour parler franchement, c'est mon attribut sur le composant, qui peut être utilisé au sein de l'élément composant !

Regardons d’abord l’exemple le plus simple ! !

Nous définissons un attribut par exemple sur l'élément (définissez-le comme vous le souhaitez !), puis utilisons le composant child, puis ajoutons l'attribut slot-scope à l'élément du modèle. ! ! Donnez-lui un nom aléatoire a

Nous imprimons a et constatons qu'il s'agit de {"say" : "Bonjour"}, qui est la paire clé-valeur composée des attributs et des valeurs sur l'emplacement ! ! !

C'est l'emplacement de la lunette !

Je peux utiliser les attributs/valeurs du composant sur l'élément du composant ! !

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

Regardez à nouveau l'exemple suivant :

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

Regardez le résultat de sortie

En savoir plus sur les machines à sous dans Vue

Recommandations associées :

Un résumé des questions d'entretien Front-end Vue en 2020 (avec réponses)

Recommandation du didacticiel Vue : 2020 dernières sélections de didacticiels vidéo 5 vue.js

Pour plus de connaissances liées à la programmation, veuillez visiter : Introduction à la programmation ! !

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Cet article est reproduit dans:. en cas de violation, veuillez contacter admin@php.cn Supprimer