将父组件的内容放到子组件指定的位置叫做内容分发
//在父组件里使用子组件 <son-tmp> <div>我是文字,我需要放到son-tmp组件里面制定的位置</div> </son-tmp>
单个插槽
父组件app.vue
<template> <div id="app"> <test-slot> <span>我是父组件里的文字,但是我要被放到子组件里</span> </test-slot> </div> </template> <script> import testSlot from './components/testSlot' export default { data(){ return { } }, components:{ testSlot } } </script> <style> </style>
子组件testSlot.vue
<template> <div> <h3>test-slot</h3> //父组件里的span会替换掉slot所以这里的123是看不见的 //如果父组件在使用子组件testSlot的时候不在里面加内容则这里的slot会显示出来 <slot>123</slot> </div> </template> <script> export default { data(){ return { } } } </script> <style> </style>
效果图:
多个插槽也叫具名插槽
具名插槽就是将某个名字的内容插到子组件对应名字里面去
父组件app.vue
<template> <div id="app"> //使用子组件testSlot <test-slot> //slot=one这个div会替换掉子组件里name="one"的slot标签 <div slot="one"> <span>one</span> <span>第一个</span> </div> //这个div没有用slot指定名字所以会替换掉子组件里没有name属性的slot标签 <div> <span>此div没有slot</span> </div> //slot=two这个div会替换掉子组件里name="two"的slot标签 <div slot="two"> <span>two</span> <span>第二个</span> </div> </test-slot> </div> </template> <script> import testSlot from './components/testSlot' export default { data(){ return { } }, components:{ testSlot } } </script> <style> </style>
子组件testSlot.vue
<template> <div class="testSlot"> <div class="noneSlot"> <slot></slot> </div> <div class="test-two"> <slot name="two"></slot> </div> <div class="test-one"> <slot name="one"></slot> </div> </div> </template> <script> export default { data(){ return { } } } </script> <style> </style>
作用域插槽(将子组件的值传到父组件供使用)
父组件app.vue
<template> <div id="app"> <h2>app</h2> <test-slot :items="items"> <template slot-scope="props"> <span>{{ props.addr }}</span> <span>{{ props.cname }}</span> <span>{{ props.age }}</span> </template> </test-slot> </div> </template> <script> import testSlot from './components/testSlot.vue' export default { data (){ return { items:[ { text:'文字1' , cname:'tom' , addr:'usa' }, { text:'文字2' , cname:'wangwu' , addr:'uk' }, { text:'文字3' , cname:'zhangsan' , addr:'un' } ] } }, methods:{ }, components:{ testSlot } } </script> <style> </style>
子组件testSlot.vue
<template> <div class="hello"> <slot :cname="items[2].cname"></slot> <slot :addr="items[2].addr"></slot> <slot age="18"></slot> </div> </template> <script> export default { data () { return { num:100 } }, props:['items'], methods:{ }, created(){ console.log('items',this.$props.items); } } </script> <style scoped> </style>
效果图:
以上所述是小编给大家介绍的vue使用插槽分发内容slot的用法详解整合,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对网站的支持!
华山资源网 Design By www.eoogi.com
广告合作:本站广告合作请联系QQ:858582 申请时备注:广告合作(否则不回)
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
华山资源网 Design By www.eoogi.com
暂无评论...
P70系列延期,华为新旗舰将在下月发布
3月20日消息,近期博主@数码闲聊站 透露,原定三月份发布的华为新旗舰P70系列延期发布,预计4月份上市。
而博主@定焦数码 爆料,华为的P70系列在定位上已经超过了Mate60,成为了重要的旗舰系列之一。它肩负着重返影像领域顶尖的使命。那么这次P70会带来哪些令人惊艳的创新呢?
根据目前爆料的消息来看,华为P70系列将推出三个版本,其中P70和P70 Pro采用了三角形的摄像头模组设计,而P70 Art则采用了与上一代P60 Art相似的不规则形状设计。这样的外观是否好看见仁见智,但辨识度绝对拉满。
更新日志
2024年11月14日
2024年11月14日
- 周深 /Faouzia《解密 电影原声带》[FLAC/分轨][199.46MB]
- 英雄联盟s14亚军队伍是哪支 英雄联盟s14亚军队伍介绍
- 英雄联盟s14夺冠队伍是哪支 英雄联盟s14夺冠队SKT T1队伍介绍
- faker三冠王是哪几个赛季 faker三冠王赛季介绍
- 岩贵-音乐磁场(AI调音)2CD[WAV]
- 童丽《千愁记旧情》HQII头版限量编号2024[低速原抓WAV+CUE]
- 瑞鸣十五周年纪念3[HQCD限量编号头版][低速原抓WAV+CUE]
- 任天堂专利展示新VR外设:或会随同NS继任机型推出
- 博主制作“Switch 2”模型 与现有掌机对比
- 网友热议IGN为《马路RPG》打5分:要是多元化就能9分了
- 群星《从21世纪安全撤离 电影原声音乐专辑》[320K/MP3][191.19MB]
- 群星《从21世纪安全撤离 电影原声音乐专辑》[FLAC/分轨][592.38MB]
- 群星《奔赴!万人现场 第5期》[320K/MP3][106.99MB]
- 许魏洲.2024-CrossFever交互热爱【智慧大狗】【FLAC分轨】
- BEYOND.1993-FINAL.LIVE.WITH家驹【华纳】【WAV+CUE】