前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Vue 匿名、具名和作用域插槽的使用

Vue 匿名、具名和作用域插槽的使用

作者头像
JS菌
发布2019-05-06 15:10:50
8700
发布2019-05-06 15:10:50
举报
文章被收录于专栏:JS菌JS菌

Vue 匿名、具名和作用域插槽的使用

⭐️ 更多前端技术和知识点,搜索订阅号 JS 菌 订阅

Vue 中的插槽在开发组件的过程中其实是非常重要并且好用的。Vue 的插槽也没有说很难使用,这篇文章简明扼要的介绍了三种插槽的用法。?

匿名插槽

子组件定义 slot 插槽,但并未具名,因此也可以说是默认插槽。只要在父元素中插入的内容,默认加入到这个插槽中去。?

代码语言:javascript
复制
<template>
  <div>
    hello <slot>陌生人</slot>
  </div>
</template>

这里定义了一个默认插槽,只要往里头丢东西,就会被加入到这个插槽里面

⚠️ slot 元素里面可以加入一系列后备内容,一旦父元素没有插入任何信息,那么就会渲染后备内容。

代码语言:javascript
复制
<my-comp>
    oli
</my-comp>

如在父组件中使用这个子组件,并插入 oli 字符串,效果如下:

具名插槽

具名插槽可以出现在不同的地方,不限制出现的次数。只要匹配了 name 那么这些内容就会被插入到这个 name 的插槽中去。?

代码语言:javascript
复制
<template>
  <div>
    <slot name="nav"></slot>
    <br/>
    <slot name="content"></slot>
    <br/>
    <slot name="footer"></slot>
  </div>
</template>

比如上述代码定义了三个具名插槽。在父组件中即可使用 slot 属性插入到对应的插槽中:

代码语言:javascript
复制
<template>
  <div>
    <my-comp>
      <template slot="nav">navigator</template>
      <template slot="footer">footer</template>
      <template slot="content">content</template>
    </my-comp>
  </div>
</template>

另外,顺序并不重要,content 在 footer 下方但依然能够按照 slot 定义的顺序渲染:

作用域插槽

通常情况下普通的插槽是父组件使用插槽过程中传入东西决定了插槽的内容。但有时我们需要获取到子组件提供的一些数据,那么作用域插槽就排上用场了。?

在子组件中创建 slot 并通过 v-bind 绑定数据 prop 的形式传入数据:

代码语言:javascript
复制
<slot :data="data"></slot>

在组件 data 中创建数据:

代码语言:javascript
复制
export default {
  name: 'MyComp',
  data () {
    return {
      data: { // 内部状态
        username: 'oli'
      }
    }
  }
}

这样就可以在插槽中访问到子元素的数据了:

代码语言:javascript
复制
<template v-slot:default="user">{{user.data.username}}</template>

也可以不书写 default 关键字,默认就是假定对应默认插槽

代码语言:javascript
复制
<template v-slot="user">{{user.data.username}}</template>

使用 v-slot 绑定一个命名空间 user,这样就可以通过 user 对象引用到子组件中传入的数据了

⚠️ 与具名插槽配合时,需要明确书写对应的命名空间:

代码语言:javascript
复制
<template #:one="user">{{user.data.username}}</template>
<template #:another="user">{{user.data.username}}</template>

# 代表 v-slot 的缩写,缩写在有参数的情况下才会生效

动态插槽名

另外,2.6 版本的 vue 还加入了动态插槽名的功能,用来动态的定义插槽名称:

代码语言:javascript
复制
<template #:[dynamicSlotName]></template>

https://cn.vuejs.org/v2/guide/components-slots.html#%E5%8A%A8%E6%80%81%E6%8F%92%E6%A7%BD%E5%90%8D

本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2019-04-19,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 JS菌 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • Vue 匿名、具名和作用域插槽的使用
    • 匿名插槽
      • 具名插槽
        • 作用域插槽
        领券
        问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档