当前位置: 首页 > news >正文

Vue(十一)默认插槽、具名插槽、作用域插槽

文章目录

  • 一、需求
  • 二、插槽
    • 1. 默认插槽
    • 2. 具名插槽
    • 3. 作用域插槽

一、需求

有三个Category组件,展示不同的内容。
需求:美食模块需要展示图片,游戏模块还是文字,电影模块展示预告片。
在这里插入图片描述

<!--App组件-->
<template>
  <div class="container">
    <Category :listData="foods" title="美食"> </Category>
    <Category :listData="games" title="游戏"> </Category>
    <Category :listData="films" title="电影"> </Category>
  </div>
</template>
<script>
  data () {
    return {
      foods: ['火锅', '烧烤', '小龙虾'],
      games: ['超级玛丽', '魂斗罗'],
      films: ['寻梦环游记', '小黄人大眼萌']
    }
  }
</script>
<!--Category组件-->
<template>
  <div class="content">
    <h3 class="title">{{ title }}</h3>
    <ul>
      <li v-for="(item, index) in listData" :key="index">{{ item }}</li>
    </ul>
  </div>
</template>
<script>
 props: ['listData', 'title']
</script>

二、插槽

作用:让父组件可以向子组件指定位置插入html结构,也是一种组件间通信的方式。

1. 默认插槽

<!--父组件中:-->
     <Category>
        <div>html结构1</div>
     </Category>
<!--子组件中:-->
    <template>
        <div>
           <!-- 定义插槽,相当于在这里挖了个坑,等待组件的使用者来填充 -->
           <slot>插槽默认内容...</slot>
        </div>
    </template>

在这里插入图片描述
插槽里的这些样式放在App里也行,放在Category里也行。


在这里插入图片描述

2. 具名插槽

当子组件中包含多个插槽时,需要给每个插槽起名字
起名字:指定name属性
使用具名插槽:

  • slot = '插槽名'
  • 如果使用了template, 还可以v-slot:footer来指定使用哪个插槽(这种方式只有template可以这样写)

子组件:

<!--Category组件-->
<template>
  <div class="content">
    <h3 class="title">{{ title }}</h3>
    <slot name="center"></slot>
    <slot name="footer"></slot>
  </div>
</template>

父组件:

<!--App.vue组件-->
  <div class="container">
    <Category title="美食">
      <img slot="center" src="../public/food.jpg" alt="" />
      <div slot="footer" class="foot">
        <a href="">更多美食</a>
        <a href="">更多美食</a>
      </div>
    </Category>
    
    <Category title="游戏">
      <ul slot="center">
        <li v-for="(g, index) in games" :key="index">{{ g }}</li>
      </ul>
      <a href="#" slot="footer">单机游戏</a>
    </Category>
    
    <Category title="电影">
      <video src="https://vjs.zencdn.net/v/oceans.mp4"></video>
      <template v-slot:footer>
        <div class="foot">
          <a href="http://www.atguigu.com">经典</a>
          <a href="http://www.atguigu.com">热门</a>
          <a href="http://www.atguigu.com">推荐</a>
        </div>
      </template>
    </Category>
  </div>

在这里插入图片描述
如果插槽不指定名称,使用的时候就会出现多个同样的内容
在这里插入图片描述

在这里插入图片描述

3. 作用域插槽

子组件通过插槽给父组件传值,必须要写template来接收传过来的值。

理解:数据在组件的自身,但根据数据生成的结构需要组件的使用者来决定。(games数据在Category组件中,但使用数据所遍历出来的结构由App组件决定)

子组件Category

<template>
  <div class="content">
    <slot :films="films"></slot>
  </div>
</template>

<script>
  data () {
    return {
      films: ['寻梦环游记', '小黄人大眼萌']
    }
  }
</script>

父组件App.vue

  <div class="container">
    <Category>
      <!-- template必须要写 -->
      <template scope="scopeData">
      <!--查看scopeData具体是什么-->
      {{scopeData}}
        <ul>
          <li v-for="(item, index) in scopeData.films" :key="index"> {{ item }}</li>
        </ul>
      </template>
    </Category>
  </div>

1、 scopeData具体内容是什么?
是一个对象
在这里插入图片描述
2、获取scope数据的简单方式,解构赋值

 <template scope="{films}">
   <ul>
     <li v-for="(item, index) in films" :key="index"> {{ item }}</li>
   </ul>
 </template>

3、获取数据还有一种方式

语法:slot-scope="{films}

 <template slot-scope="{films}">...</template>

用哪种方式都行,是新旧api的原因。slot-scope是新api获取数据的方式,scope是旧api获取数据的方式

相关文章:

  • 【ORACLE】listagg() 函数
  • 第4章 汇编语言和汇编软件
  • JAVA vs Python:谁更适合后端开发?
  • 使用C++编写接口调用PyTorch模型,并生成DLL供.NET使用
  • UFUG2601-OJ 2048 Game
  • SpringMVC 第一次复学笔记
  • AI智能电销机器人的优势是什么,有什么特点?
  • vscode使用
  • 【Postgresql】地理空间数据的存储与查询,
  • 速盾:防御ddos攻击的几大有效方法是什么?
  • 笔记:应用Visual Studio Profiler分析CPU使用情况
  • 4、Django Admin对自定义的计算字段进行排序
  • 论tomcat线程池和spring封装的线程池
  • 第二章 数据访问:JPA
  • 探索Ansible自动化运维:提高效率的关键工具
  • zabbix和prometheus介绍;云原生
  • 数据结构之 “单链表“
  • 2d像素游戏基本架构
  • C++ 容器迭代器失效
  • 前端算法面试题1--栈、队列、链表、字典与哈希表
  • 中青旅:第一季度营业收入约20.54亿元,乌镇景区接待游客数量同比减少6.7%
  • 解放日报头版聚焦“人民城市”:共建共享展新卷
  • 专访丨青年作家杜梨:以动物的视角去观察这个世界
  • 四川省社科联期刊:不建议在读硕士、博士将导师挂名为第一作者
  • 上海乐高乐园建设进入最后冲刺,开园限量纪念年卡将于5月开售
  • 跨海论汉|专访白馥兰:对中国农业史的兴趣,从翻译《齐民要术》开始