作用域插槽 (如果在插槽中可以直接访问父组件中的data, 但是如果在子组件的模板template 中访问父组件中的data, 需要用到组件通信 作用域插槽)

渲染作用域 : 该插槽可以访问与模板其余部分相同的实例 property (即相同的“作用域”)。

        作用域: 本质用来访问数据

        有时让插槽内容能够访问子组件中才有的数据是很有用的。当一个组件被用来渲染一个项目数组时,这是一个常见的情况,我们希望能够自定义每个项目的渲染方式。
       
 1  <div id="app">
 2         <p>{{msg}}</p>
 3         <!--  如果在插槽中可以直接访问父组件中的data, 但是如果在子组件的模板template 中访问父组件中的data, 需要 组件通信 -->
 4         <child v-bind:msg="msg">
 5             <!-- obj是自定义的对应的是下面的第一个arr 接受的是一个对象 都是自定义的名字 用来接收默认插槽提供的数据 -->
 6             <template v-slot='obj'>  // obj 就是对应子组件data数据里面的arr整个数组
 7                 <p v-for="item in obj.arr">{{obj}} --- {{item}}</p>
 8             </template>
 9 
10             <!-- 接收具名插槽提供的数据 -->
11             <!-- <template v-slot:nav="obj2">
12                 <strong>{{obj2.msg}}</strong>
13             </template> -->
14 
15             <!--  插槽解构 -->
16             <template v-slot:nav="{a, b}">
17                 <strong>{{a}} ==== {{b}}</strong>
18             </template>
19         </child>
20     </div>
 1 <script src="./js/vue.global.min.js"></script>
 2     <script>
 3         const app = Vue.createApp({
 4             data() {
 5                 return {
 6                     msg: '定义数据'
 7                 }
 8             }
 9         })
10 
11         const Child = {
12             data() {
13                 return {
14                     arr: [1, 23, 4, 5]
15                 }
16             },
17             //  插槽 prop 
18             // 第一个arr是自定义的属性名 第二个arr是child data数据里面的arr
19             template: `
20                 <div>
21 
22                     <slot :arr='arr' title='静态数据'></slot>
23                     <strong>{{msg}}</strong>
24                     <hr><hr>
25                     <slot name='nav' msg='具名插槽提供数据' a='100' b='300'>具名插槽</slot>
26                 </div>
27             `,
28             props: ['msg']
29         }
30 
31         app.component('Child', Child)
32         app.mount('#app')
33     </script>

 

posted @ 2022-07-13 14:20  请善待容嬷嬷  阅读(172)  评论(0编辑  收藏  举报