Vue_使用插槽(slot)

简介: 当父组件向子组件传值的时候,有时候,父组件传的并不是单纯的数值、字符串,有可能是带标签(DOM)的数据,那么如何传值呢? 如果我们像正常父向子传值那样操作。 <slott content="<p>hello,slot</p>"></slott> 1子组件: <template> <div cl.

当父组件向子组件传值的时候,有时候,父组件传的并不是单纯的数值、字符串,有可能是带标签(DOM)的数据,那么如何传值呢?

如果我们像正常父向子传值那样操作。

 <slott content="<p>hello,slot</p>"></slott>

 
 
  • 1

子组件:

<template> <div class="slott"> <div>{{content1}}</div> </div> </template> <script>
export default{
 props:['content'],
 data(){
 return{
 content1 : this.content,
 }
 }
 } 
</script>

 
 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15

效果:

这里写图片描述

我们可以看到显示的并不是我们想要的,当然我们可以在子组件在接受的时候,使用v-html。

<template> <div class="slott"> <div v-html='content1'></div> </div> </template>

 
 
  • 1
  • 2
  • 3
  • 4
  • 5

效果:

这里写图片描述
这里写图片描述

但是缺点是:多生成了一个div标签,那换成template模板占位符呢?是渲染不出来这个效果的。

div标签虽然可以实现,但是如果有很多DOM元素呢?显然不好控制,所以Vue中提供了slot插槽的方式

一.插槽

在父组件中直接插入正常的DOM结构

 <slott> <p>你好solt!</p> </slott>

 
 
  • 1
  • 2
  • 3

然后在子组件用<slot>来代替,所以说slot是保留字,不能当做id的

<template> <div class="slott"> <slot></slot> </div> </template> <script>
export default{
 props:['content'],
 data(){
 return{
 content1 : this.content,
 }
 } 
</script>

 
 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14

效果:

这里写图片描述

效果:

这里写图片描述

二.引入header组件

在实际开发中,我们经常会遇到一种情况,将 header和footer传进来。

在父组件中:

<slott> <div>header</div> <div>footer</div> </slott> 

 
 
  • 1
  • 2
  • 3
  • 4

在子组件中:

 <slot></slot> <div>content</div> <slot></slot>

 
 
  • 1
  • 2
  • 3

结果:

这里写图片描述

这是为什么呢?slot标签代表的显示插槽的所有的内容,那如何达到我们想要的效果呢?我们可以用具名插槽。

父组件的插槽中命名。

<slott> <div slot="header">header</div> <div slot="footer">footer</div> </slott> 

 
 
  • 1
  • 2
  • 3
  • 4

在子组件引用名称

 <slot name="header"></slot> <div>content</div> <slot name="footer"></slot>

 
 
  • 1
  • 2
  • 3

效果:

这里写图片描述

附:slot标签可以有默认值,如果找不到相关的插槽,就会显示默认值。

在插槽中去掉header

<slott> <div slot="footer">footer</div> </slott> 

 
 
  • 1
  • 2
  • 3

在调用的时候找不到header的话,就会显示默认的内容

 <slot name="header">default</slot> <div>content</div> <slot name="footer"></slot>

 
 
  • 1
  • 2
  • 3

效果:

这里写图片描述

二.作用域插槽

有时候,我们在使用插槽的时候,希望父组件可以控制插槽的内容,

什么时候用作用域插槽呢?当子组件做循环或者某一部分它的DOM结构应该由外部传递进来的时候,这个时候我们用作用域插槽

使用作用域插槽,子组件会向父组件的作用域里传递数据。

父组件使用插槽,要包含在template标签中。props是自定义的名字

eg:

<slott> <template slot-scope="props"> <h1>{{props.item}}</h1> </template> </slott> 

 
 
  • 1
  • 2
  • 3
  • 4
  • 5

子组件往外传递数据:

 <slot 
 v-for="item of list" 
 :item=item>
 </slot>

//data中: return{
 list:[1,2,3,4]
 }


 
 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10

效果:

这里写图片描述

父组件也可以改为li:

<slott> <template slot-scope="props"> <li>{{props.item}}</li> </template> </slott> 

 
 
  • 1
  • 2
  • 3
  • 4
  • 5

效果:

这里写图片描述

这样的话,就实现了由父组件决定实现的内容

原文发布时间:06月30日

原文作者:_dalianmiao

本文来源CSDN博客如需转载请紧急联系作者

相关文章
|
9天前
|
缓存 JavaScript 前端开发
vue学习第四章
欢迎来到我的博客!我是瑞雨溪,一名热爱JavaScript与Vue的大一学生。本文介绍了Vue中计算属性的基本与复杂使用、setter/getter、与methods的对比及与侦听器的总结。如果你觉得有用,请关注我,将持续更新更多优质内容!🎉🎉🎉
vue学习第四章
|
9天前
|
JavaScript 前端开发
vue学习第九章(v-model)
欢迎来到我的博客,我是瑞雨溪,一名热爱JavaScript与Vue的大一学生,自学前端2年半,正向全栈进发。此篇介绍v-model在不同表单元素中的应用及修饰符的使用,希望能对你有所帮助。关注我,持续更新中!🎉🎉🎉
vue学习第九章(v-model)
|
9天前
|
JavaScript 前端开发 开发者
vue学习第十章(组件开发)
欢迎来到瑞雨溪的博客,一名热爱JavaScript与Vue的大一学生。本文深入讲解Vue组件的基本使用、全局与局部组件、父子组件通信及数据传递等内容,适合前端开发者学习参考。持续更新中,期待您的关注!🎉🎉🎉
vue学习第十章(组件开发)
|
14天前
|
JavaScript 前端开发 UED
vue学习第二章
欢迎来到我的博客!我是一名自学了2年半前端的大一学生,熟悉JavaScript与Vue,目前正在向全栈方向发展。如果你从我的博客中有所收获,欢迎关注我,我将持续更新更多优质文章。你的支持是我最大的动力!🎉🎉🎉
|
14天前
|
JavaScript 前端开发 开发者
vue学习第一章
欢迎来到我的博客!我是瑞雨溪,一名热爱JavaScript和Vue的大一学生。自学前端2年半,熟悉JavaScript与Vue,正向全栈方向发展。博客内容涵盖Vue基础、列表展示及计数器案例等,希望能对你有所帮助。关注我,持续更新中!🎉🎉🎉
|
JavaScript
初识 Vue(19)---(Vue 中使用插槽(slot))
Vue 中使用插槽(slot) 案例:子组件中的一部分内容是根据父组件传递来的 DOM 来进行显示 Vue 中使用插槽(slot) Vue.
1260 0
|
15天前
|
JavaScript 前端开发
如何在 Vue 项目中配置 Tree Shaking?
通过以上针对 Webpack 或 Rollup 的配置方法,就可以在 Vue 项目中有效地启用 Tree Shaking,从而优化项目的打包体积,提高项目的性能和加载速度。在实际配置过程中,需要根据项目的具体情况和需求,对配置进行适当的调整和优化。
|
15天前
|
存储 缓存 JavaScript
在 Vue 中使用 computed 和 watch 时,性能问题探讨
本文探讨了在 Vue.js 中使用 computed 计算属性和 watch 监听器时可能遇到的性能问题,并提供了优化建议,帮助开发者提高应用性能。
|
15天前
|
存储 缓存 JavaScript
如何在大型 Vue 应用中有效地管理计算属性和侦听器
在大型 Vue 应用中,合理管理计算属性和侦听器是优化性能和维护性的关键。本文介绍了如何通过模块化、状态管理和避免冗余计算等方法,有效提升应用的响应性和可维护性。
|
15天前
|
存储 缓存 JavaScript
Vue 中 computed 和 watch 的差异
Vue 中的 `computed` 和 `watch` 都用于处理数据变化,但使用场景不同。`computed` 用于计算属性,依赖于其他数据自动更新;`watch` 用于监听数据变化,执行异步或复杂操作。
下一篇
无影云桌面