What is a slotA slot is a placeholder in a child component that is provided to a parent component, represented by <slot></slot>. The parent component can fill any template code in this placeholder, such as HTML, components, etc. The filled content will replace the <slot></slot> tag of the child component. Understanding of default slotsJust use the full tag () to write the corresponding configuration in its full tag (for example: the functions we need) Then use the default slot tag to put the written content into this slot (this slot generally exists in the child component, so you can give the child component what the parent component has written) Regarding the configuration style written in the complete tag, we can write it in both the parent component and the child component (because, 1. When the style is written in the parent component, the style has been rendered and then put into the child component; 2. When the style is written in the child component, put the configuration into the slot, and the child component where the slot is located has a CSS style that will render our configuration) Code Snippet①Category.vue <template> <div class="category"> <h3>{{ title }}Category</h3> <!-- Define a default slot, then the content of the tag body in the corresponding component tag in App.vue will be placed in this slot--> <slot></slot> </div> </template> <script> export default { name: "Category", props: ["title"], }; </script> <style> .category { background-color: skyblue; width: 200px; height: 300px; } h3 { text-align: center; background-color: orange; } </style> ②App.vue <template> <div class="container"> <Category title="Food"> <img src="https://zqcdn.itzjj.cn/static/skin/mfw0321/static/picture/dj_scv.jpg" alt="1" /> </Category> <Category title="Games" :listData="games"> <ul> <!-- At this time, because the variables are directly in app.vue, you can directly traverse game After traversing, use the slot function to pass it to Category.vue --> <li v-for="(g, index) in games" :key="index"> {{ g }} </li> </ul></Category > <Category title="Movies" :listData="films"> <!-- controls allow the video to play --> <video Controls src="http://clips.vorwaerts-gmbh.de/big_buck_bunny.mp4" ></video> </Category> </div> </template> <script> import Category from "./components/Category"; export default { name: "App", components: { Category }, data() { return { foods: ["fire", "your meat", "meatballs"], games: ["Red Alert Online", "Cross Fire", "Audition"], films: ["The Godfather", "Shock Wave", "Awesome"], }; }, }; </script> <style> .container { display: flex; justify-content: space-around; } video width: 100%; } img { width: 100%; } </style> SummarizeThis is the end of this article about vue default slot. For more relevant vue default slot content, please search 123WORDPRESS.COM's previous articles or continue to browse the following related articles. I hope everyone will support 123WORDPRESS.COM in the future! You may also be interested in:
|
<<: Detailed process of deploying MySQL with docker (common applications deployed with docker)
>>: How to set a dotted border in html
This article example shares the specific code of ...
To beautify the table, you can set different bord...
First download the latest MySQL 5.7.17 Community ...
Table of contents 1. MySQL compilation and instal...
1 Stored Procedure 1.1 What is a stored procedure...
1. Mind Map 2. How to build a container 2.1 Prepa...
Everyone must be familiar with table. We often en...
Two days ago, I took advantage of the Double 11 s...
Table of contents 1. Supplementary knowledge poin...
Hello everyone, I am Qiufeng. Recently, WeChat ha...
In the previous article, we used Docker to build ...
need: Merge identical items of one field and sort...
CSS3Please Take a look at this website yourself, ...
Table of contents 1. fill() syntax 2. Use of fill...
Preface Semicolons in JavaScript are optional, an...