Vue 插槽

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

一、默认插槽

使用方式:

父组件:

<xxxx>

<div>html结构</div>

</xxxx>

子组件:

<template>

<div>

<slot>插槽默认内容........</slot>

</div>

</template>

javascript 复制代码
/*    App.vue    */
<template>
	<div class="container">
    <Category title="foods">
      <img src="https://s3.ax1x.com/2021/01/16/srJlq0.jpg" alt="">
    </Category>
    <Category title="games">
      <ul>
          <li v-for="(item,index) in games" :key="index">{{ item }}</li>
      </ul>
    </Category>
    <Category title="films">
      <video controls src="http://clips.vorwaerts-gmbh.de/big_buck_bunny.mp4"></video>
    </Category>
	</div>
</template>

<script>
	import Category from './Components/Category'
	export default {
		name:'App',
		components:{Category},
		data() {
			return {
				foods:['火锅','烧烤','小龙虾','牛排'],
				games:['红色警戒','穿越火线','劲舞团','超级玛丽'],
				films:['《教父》','《拆弹专家》','《你好,李焕英》','《尚硅谷》']
			}
		},
	}
</script>

<style>
	.container{
		display: flex;
		justify-content: space-around;
	}
  img,video{
    width: 100%;
  }
</style>
javascript 复制代码
/*    Category.vue    */
<template>
    <div>
        <h2>{{ title }}</h2>
        <slot></slot>
        
    </div>
</template>

<script>
    export default {
        name:'Category',
        props:['title','listData']
    }
</script>

<style lang="less" scoped>
    div{
        width: 200px;
        height: 300px;
        background-color: skyblue;
    }
    h2{
        text-align: center;
        background-color: orange;
    }
</style>

二、具名插槽

使用方式:

父组件:

<xxxx>

<template slot="center">

<div>html结构1</div>

</template>

<template slot="footer">

<div>html结构2</div>

</template>

</xxxx>

子组件:

<template>

<div>

<slot name="center">插槽默认内容........</slot>

<slot name="footer">插槽默认内容........</slot>

</div>

</template>

javascript 复制代码
/*    App.vue    */
<template>
	<div class="container">
    <Category title="foods">
      <img slot="center" src="https://s3.ax1x.com/2021/01/16/srJlq0.jpg" alt="">
      <a class="foot" slot="footer" href="http://www.baidu.com">更多美食</a>
    </Category>
    <Category title="games">
      <ul slot="center">
          <li v-for="(item,index) in games" :key="index">{{ item }}</li>
      </ul>
      <div slot="footer" class="foot">
        <a href="http://www.baidu.com">单机游戏</a>
        <a href="http://www.baidu.com">网络游戏</a>
      </div>
    </Category>
    <Category title="films">
      <video slot="center" controls src="http://clips.vorwaerts-gmbh.de/big_buck_bunny.mp4"></video>
      <template v-slot:footer>
        <div class="foot">
          <a href="http://www.baidu.com">经典</a>
          <a href="http://www.baidu.com">热门</a>
          <a href="http://www.baidu.com">推荐</a>
        </div>
        <h4>欢迎前来观影</h4>
      </template>
    </Category>
	</div>
</template>

<script>
	import Category from './Components/Category'
	export default {
		name:'App',
		components:{Category},
		data() {
			return {
				foods:['火锅','烧烤','小龙虾','牛排'],
				games:['红色警戒','穿越火线','劲舞团','超级玛丽'],
				films:['《教父》','《拆弹专家》','《你好,李焕英》','《尚硅谷》']
			}
		},
	}
</script>

<style>
	.container,.foot{
		display: flex;
		justify-content: space-around;
	}
  img,video{
    width: 100%;
  }
  h4{
    text-align: center;
  }
  a{
    padding-top: 10px;
  }
</style>
javascript 复制代码
/*    Category.vue    */
<template>
    <div class="main">
        <h2>{{ title }}</h2>
        <slot name="center"></slot>
        <slot name="footer"></slot>
    </div>
</template>

<script>
    export default {
        name:'Category',
        props:['title','listData']
    }
</script>

<style lang="less" scoped>
    .main{
        width: 200px;
        height: 300px;
        background-color: skyblue;
    }
    h2{
        text-align: center;
        background-color: orange;
    }
</style>

三、作用域插槽

1.理解:数据在组件的自身,但根据数据生成的结构需要组建的使用者来决定。

2.使用方法:

父组件:

<xxxx>

<template scope="scopeData">

<ul>

<li v-for="g in scopeData.games" :key="g">{{g}}</li>

</ul>

</template>

</xxxx>

<xxxx>

<template slot-scope="scopeData">

<h4 v-for="g in scopeData.games" :key="g">{{g}}</h4>

</template>

</xxxx>

子组件:

<template>

<div>

<slot :games="games"></slot>

</div>

</template>

<script>

export default {

name:'Category',

props:['title'],

data() {

return {

games:['红色警戒','穿越火线','劲舞团','超级玛丽']

}

},

}

</script>

javascript 复制代码
/*    App.vue    */
<template>
	<div class="container">
    <Category title="games">
      <template slot-scope="{games}">
          <ul>
            <li v-for="(item,index) in games" :key="index">{{ item }}</li>
          </ul>
      </template>
    </Category>
    <Category title="games">
      <template slot-scope="{games}">
          <ol>
            <li v-for="(item,index) in games" :key="index">{{ item }}</li>
          </ol>
      </template>
    </Category>
    <Category title="games">
      <template slot-scope="{games}">
            <h4 v-for="(item,index) in games" :key="index">{{ item }}</h4>
      </template>
    </Category>
	</div>
</template>

<script>
	import Category from './Components/Category'
	export default {
		name:'App',
		components:{Category},
		
	}
</script>

<style>
	.container,.foot{
		display: flex;
		justify-content: space-around;
	}
  img,video{
    width: 100%;
  }
  h4{
    text-align: center;
  }
  a{
    padding-top: 10px;
  }
</style>
javascript 复制代码
/*    Category.vue    */
<template>
    <div class="main">
        <h2>{{ title }}</h2>
        <slot :games="games"></slot>
    </div>
</template>

<script>
    export default {
        name:'Category',
        data() {
			return {
				games:['红色警戒','穿越火线','劲舞团','超级玛丽'],
			}
		},
        props:['title','listData']
    }
</script>

<style lang="less" scoped>
    .main{
        width: 200px;
        height: 300px;
        background-color: skyblue;
    }
    h2{
        text-align: center;
        background-color: orange;
    }
</style>
相关推荐
Irene19912 小时前
ElementPlus 与成熟后台框架对比:vue-element-plus-admin、vue-pure-admin等
前端·ui·框架·vue3
尘中客6 小时前
放弃 Echarts?前端直接渲染后端高精度 SVG 矢量图流的踩坑记录
前端·javascript·echarts·前端开发·svg矢量图·echarts避坑
FreeBuf_6 小时前
Chrome 0Day漏洞遭野外利用
前端·chrome
小彭努力中6 小时前
199.Vue3 + OpenLayers 实现:点击 / 拖动地图播放音频
前端·vue.js·音视频·openlayers·animate
2501_916007476 小时前
网站爬虫原理,基于浏览器点击行为还原可接口请求
前端·javascript·爬虫·ios·小程序·uni-app·iphone
前端大波7 小时前
Sentry 每日错误巡检自动化:设计思路与上手实战
前端·自动化·sentry
Highcharts.js8 小时前
适合报表系统的可视化图表|Highcharts支持直接导出PNG和PDF
javascript·数据库·react.js·pdf
ZC跨境爬虫8 小时前
使用Claude Code开发校园交友平台前端UI全记录(含架构、坑点、登录逻辑及算法)
前端·ui·架构
慧一居士8 小时前
Vue项目中,何时使用布局、子组件嵌套、插槽 对应的使用场景,和完整的使用示例
前端·vue.js
叫我一声阿雷吧8 小时前
JS 入门通关手册(35):执行上下文、调用栈与作用域链深度解析
javascript·作用域链·js进阶·执行上下文·调用栈·变量提升·闭包原理