Vue插槽Slot的作用是什么及怎么使用(slot,vue,编程语言)

时间:2024-05-04 22:41:12 作者 : 石家庄SEO 分类 : 编程语言
  • TAG :

希望大家仔细阅读,能够学有所成!

插槽Slot

插槽Slot的作用

初识插槽:

  • 为了让这个组件具备更强的通用性,我们不能将组件中的内容限制为固定的divspan等等这些元素;【相关推荐:vuejs视频教程】

  • 比如某种情况下我们使用组件,希望组件显示的是一个按钮,某种情况下我们使用组件希望显示的是一张图片;

  • 我们应该让使用者可以决定某一块区域到底存放什么内容和元素;

  • 所以就可以使用插槽来解决这个问题

换句话说就是,我们要是想在一个组件标签中添加新的内容,那么我们就需要在该组件内声明一个插槽,不然,添加的新内容不会被渲染

使用插槽:

  • slot元素作为插槽

  • 插入什么内容是由父元素如何使用,比如父组件插入按钮、插入图片,就会显示按钮图片,如果没有,那就不显示或许显示插槽默认的内容

  • 有时候我们希望在使用插槽时,如果没有插入对应的内容,那么我们需要显示一个默认的内容:

  • 当然这个默认的内容只会在没有提供插入的内容时,才会显示;

  • 我们可以在slot标签中设置一个默认内容

使用插槽案例:

父组件

App.vue

<template>
<divclass="app">
<!--内容是button-->
<show-messagetitle="哈哈哈">
<button>我是按钮元素</button>
</show-message>
<!--内容是超链接-->
<show-message>
<ahref="#">百度一下</a>
</show-message>

<!--没有值传递-->
<show-message></show-message>
</div>
</template>

子组件
showMessage.vue

<template>
<h3>{{title}}</h3>
<divclass="content">
<slot>
<p>我是默认值</p>
</slot>
</div>
</template>

  • 效果图:
    Vue插槽Slot的作用是什么及怎么使用
    我们可以发现,在组件showMessage里面,我们给它一个插槽,

  • App.vue, 我们给showMessage三次复用,

  • 一次为按钮一次为a标签一次什么也不加

  • 而产生的结果就是,一个为按钮,一个为a链接一个为插槽默认的p标签

我们可以看出来

  • 插槽部分想要展示什么内容由父元素进行决定, 如果插槽没有 插入东西, 那么这个插槽会被忽略

  • 也就是说,用了插槽,父元素如果用按钮,子元素就会显示按钮,父元素用标题,子元素就会显示标题

  • 如果子组件没有插槽,那就显示不出来了

具名插槽Slot

希望达到的效果是插槽对应内容的显示,这个时候我们就可以使用具名插槽:

  • 具名插槽顾名思义就是给插槽起一个名字,slot 元素有一个特殊的 attribute:name

  • 一个不带 nameslot,会带有隐含的名字 default

  • 也就是说, 我们可以给每个插槽都取上一个名字,

  • 在父组件中使用的时候, 需要包裹一个template标签, 并在template中使用

  • v-solt: 插槽名 具名插槽缩写#

父组件
App.vue

<template>
<nav-bar>
<templatev-slot:left>
<button>返回</button>
</template>

<templatev-slot:center>
<span>内容</span>
</template>

<templatev-slot:right>
<ahref="#">登录</a>
</template>
</nav-bar>
</template>

子组件
NavBar.vue
(颜色啥的css里面自己可以调,这里就不放了)

<template>
<divclass="nav-bar">
<divclass="left">
<slotname="left">left</slot>
</div>
<divclass="center">
<slotname="center">center</slot>
</div>
<divclass="right">
<slotname="right">right</slot>
</div>
</div>
</template>

效果图:
Vue插槽Slot的作用是什么及怎么使用
达到的效果是插槽对应的显示
所以这就是具名插槽的作用

动态插槽名
通过 v-slot:[dynamicSlotName]方式动态绑定一个名称。

本文:Vue插槽Slot的作用是什么及怎么使用的详细内容,希望对您有所帮助,信息来源于网络。
上一篇:php怎么创建共享内存减少负载下一篇:

4 人围观 / 0 条评论 ↓快速评论↓

(必须)

(必须,保密)

阿狸1 阿狸2 阿狸3 阿狸4 阿狸5 阿狸6 阿狸7 阿狸8 阿狸9 阿狸10 阿狸11 阿狸12 阿狸13 阿狸14 阿狸15 阿狸16 阿狸17 阿狸18