详解vue使用插槽分发内容slot的用法


Posted in Javascript onMarch 28, 2019

将父组件的内容放到子组件指定的位置叫做内容分发

//在父组件里使用子组件
<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>

效果图:

详解vue使用插槽分发内容slot的用法

多个插槽也叫具名插槽

具名插槽就是将某个名字的内容插到子组件对应名字里面去

父组件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>

详解vue使用插槽分发内容slot的用法

作用域插槽(将子组件的值传到父组件供使用)

父组件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的用法

以上所述是小编给大家介绍的vue使用插槽分发内容slot的用法详解整合,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!

Javascript 相关文章推荐
JavaScript 异步方法队列链实现代码分析
Jun 05 Javascript
JavaScript 一道字符串分解的题目
Aug 03 Javascript
jquery分页插件AmSetPager(自写)
Apr 15 Javascript
JavaScript中instanceof运算符的用法总结
Nov 19 Javascript
封装了jQuery的Ajax请求全局配置
Feb 05 Javascript
BootStrap Fileinput的使用教程
Dec 30 Javascript
Vue-cli proxyTable 解决开发环境的跨域问题详解
May 18 Javascript
详解Vue.js基于$.ajax获取数据并与组件的data绑定
May 26 Javascript
jQuery+ajax实现修改密码验证功能实例详解
Jul 06 jQuery
layui结合form,table的全选、反选v1.0示例讲解
Aug 15 Javascript
vue中filters 传入两个参数 / 使用两个filters的实现方法
Jul 15 Javascript
Vant+postcss-pxtorem 实现浏览器适配功能
Feb 05 Javascript
详解一个基于套接字实现长连接的express
Mar 28 #Javascript
微信小程序学习笔记之跳转页面、传递参数获得数据操作图文详解
Mar 28 #Javascript
微信小程序学习笔记之表单提交与PHP后台数据交互处理图文详解
Mar 28 #Javascript
深入理解es6块级作用域的使用
Mar 28 #Javascript
详解在网页上通过JS实现文本的语音朗读
Mar 28 #Javascript
详解React服务端渲染从入门到精通
Mar 28 #Javascript
微信小程序学习笔记之函数定义、页面渲染图文详解
Mar 28 #Javascript
You might like
php防注
2007/01/15 PHP
Symfony2学习笔记之模板用法详解
2016/03/17 PHP
JavaScript Event学习第五章 高级事件注册模型
2010/02/07 Javascript
javascript代码加载优化方法
2011/01/30 Javascript
Javascript base64编码实现代码
2011/12/02 Javascript
Jquery使用Firefox FireBug插件调试Ajax步骤讲解
2013/12/02 Javascript
javascript实现树形菜单的方法
2015/07/17 Javascript
javascript图片滑动效果实现
2021/01/28 Javascript
彻底解决 webpack 打包文件体积过大问题
2017/07/07 Javascript
JavaScript如何获取到导航条中HTTP信息
2017/10/10 Javascript
JS中appendChild追加子节点无效的解决方法
2018/10/14 Javascript
JS表格的动态操作完整示例
2020/01/13 Javascript
微信小程序实现聊天室
2020/08/21 Javascript
vue中配置scss全局变量的步骤
2020/12/28 Vue.js
[06:16]第十四期-国士无双绝地翻盘之撼地神牛
2014/06/24 DOTA
Python中的True,False条件判断实例分析
2015/01/12 Python
python使用socket连接远程服务器的方法
2015/04/29 Python
尝试使用Python多线程抓取代理服务器IP地址的示例
2015/11/09 Python
python中解析json格式文件的方法示例
2017/05/03 Python
Python编程实现粒子群算法(PSO)详解
2017/11/13 Python
python如何修改装饰器中参数
2018/03/20 Python
python用列表生成式写嵌套循环的方法
2018/11/08 Python
python 利用turtle库绘制笑脸和哭脸的例子
2019/11/23 Python
Python使用monkey.patch_all()解决协程阻塞问题
2020/04/15 Python
Python 的 f-string 可以连接字符串与数字的原因解析
2021/02/20 Python
Mavi牛仔裤美国官网:土耳其著名牛仔品牌
2016/09/24 全球购物
荷兰超市:DEEN
2018/03/14 全球购物
中学优秀班主任事迹材料
2014/05/01 职场文书
党的群众路线教育学习材料
2014/05/12 职场文书
2014年消防工作总结
2014/11/21 职场文书
2015年五一劳动节活动总结
2015/02/09 职场文书
爱心捐赠活动简讯
2015/07/20 职场文书
如何写好一份优秀的工作总结?
2019/06/21 职场文书
CSS3实现的水平标题菜单
2021/04/14 HTML / CSS
Eclipse+Java+Swing+Mysql实现电影购票系统(详细代码)
2022/01/18 Java/Android
Vue的列表之渲染,排序,过滤详解
2022/02/24 Vue.js