一、插槽Slot的作用

1、为了让这个组件具备更强的通用性,我们不能将组件中的内容限制为固定的div、span等等这些元素;
2、比如某些情况下我们使用组件,希望组件显示的是一个按钮,某种情况下我们使用组件希望显示的是一张图片;
3、我们应该让使用者可以决定某一块区域到底放什么内容和元素;
4、所以就可以使用插槽来解决这个问题

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

二、使用

用slot元素作为插槽;
插入声明内容是由父元素如何使用,比如父组件插入按钮、插入图片,就会显示按钮图片,如果没有,那就不显示或许显示插槽默认的内容;
有时候我们希望在使用插槽时,如果没有插入对应的内容,那么我们需要显示一个默认的内容:
当然这个默认的内容只会在没有提供插入的内容时,才会显示;
可以在slot标签中设置一个默认内容

父组件
App.vue

<template><div class="app"><!-- 内容是button --><show-message title='哈哈哈'><button>我是按钮元素</button></show-message><!-- 内容是超链接 --><show-message><a href="#">百度一下</a></show-message><!-- 没有值传递 --><show-message></show-message></div>
</template>

子组件
showMessage.vue

<template><h2>{{title}}</h2><div><slot><p>这是默认值</p></slot></div>
</template>

具名插槽Slot

希望达到的效果是插槽对应内容的显示,这个时候就可以使用具名插槽:
具名插槽顾名思义就是给插槽起个名字,slot元素有一个特殊的attribute:name;
一个不带name的slot,会带有隐含的名字 default;
也就是说,我们可以给每个插槽都取上名,
在父组件中使用的时候,需要包裹一个template标签,并且templat中使用
v-solt:插槽名 具名插槽缩写 #

父元素
App.vue

<template><nav-bar><template v-slot:left><button>返回</button></template><template v-slot:center><span>标题</span></template><template v-slot:right><a href="#">登录</a></template></nav-bar>
</template>

子组件
NavBar.vue

<template><div class='nav-bar'><div class='left'><slot name="left">left</slot></div><div class='center'><slot name="center">center</slot></div><div class='right'><slot name="right">right</slot></div></div>
</template>

动态插槽名

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

vue 中的插槽Slot基本使用和具名插槽相关推荐

  1. Vue中的Ajax②(slot插槽)

    文章目录 案例引入 默认插槽 具名插槽 作用域插槽 总结 案例引入 我们现在有一个需求: 代码: App组件: <template><div class="containe ...

  2. vue中的slot——单个插槽和具名插槽

    v-slot顾名思义,中文意思是插槽.如果你平时常用组件化开发,那相信你对插槽肯定不陌生,它的主要作用就是可以在父组件中将自定义内容插入到子组件中,这句话比较拗口,可以先看个基础的插槽示例. 一.单个 ...

  3. slot属性值_深入理解vue中的slot与slot

    作者/云荒杯倾 写在前面 vue中关于插槽的文档说明很短,语言又写的很凝练,再加上其和methods,data,computed等常用选项使用频率.使用先后上的差别,这就有可能造成初次接触插槽的开发者 ...

  4. Vue中slot与slot-scope的理解及使用

    以前使用过vue,但是从来没有用过插槽slot,最近突然看到slot,发现有点不会用,因此决定系统的学习一下插槽slot. 但是在查看了vue文档后,感觉说的太笼统,让人难以理解,因此在网上查了很多资 ...

  5. vue 中的solt插槽

    插槽的种类: 插槽分为3种,一种是默认插槽.一种是具名插槽.一种是作用域插槽. 插槽的定义: 在子组件中用 <solt></solt> 划出一块区域用来显示父组件中的页面结构, ...

  6. vue插槽样式_Vue 插槽(slot)使用(通俗易懂)

    因为在2.6.0中,具名插槽 和 作用域插槽 引入了一个新的统一的语法 (即v-slot 指令).它取代了 slot 和 slot-scope,并且现在网上都说的是一些老版本的内容,官方文档不太容易理 ...

  7. vue2到vue3中插槽slot变化详解---从slot,slot-scope到v-slot的变化

    文章目录 前言 默认插槽 具名插槽 作用域插槽 解构prop的写法 v-solt 默认插槽 独占默认插槽 v-solt具名插槽 v-solt作用域插槽 解构props的写法 动态插槽名 插槽的缩写 前 ...

  8. VUE之组件(插槽slot与可复用组件)

    插槽slot 首先创建个基础组件,然后在页面调用显示,如下所示 <div id="app"><blog></blog></div>& ...

  9. vue插槽--slot

    2019独角兽企业重金招聘Python工程师标准>>> vue插槽--slot,在很多三方的UI框架里大量的使用了插槽,像现在用的比较多的饿了么的ElementUI 在这里有自己写的 ...

最新文章

  1. 【每日一算法】整数反转
  2. VS2017中使用码云上传项目以及问题汇总
  3. Python类的多态和多态性
  4. D3js(六):支持css的tooltips
  5. django建表报错
  6. SQL Server Error 15404解决方案
  7. QT实现图像处理-傅立叶变换、傅立叶反变换、平滑、锐化与模板匹配
  8. strutr2运行流程
  9. java汉字偏旁拆分,常见部首的拆分
  10. Y Combinator 创业课 2018 @北京
  11. 通过源码成功启动odoo 10.0
  12. kali linux工具pyrit,在Kali Linux上安装cuda、pyrit-cuda以及optimus
  13. 【2020年】Android开发学习思考及规划
  14. 基于plc的污水处理,组态王动画仿真,带PLC源代码,组态王源代码
  15. 蚁群算法c语言实现加注释,蚁群算法代码实现
  16. Apache服务器访问过慢分析及解决
  17. Leetcode:125.验证回文串,917仅仅反转字母,387字符串的第一个唯一字符
  18. ROS系统SLAM基础学习:gazebo仿真机器人自主导航
  19. 传智教育|Java目前市场趋势怎么样?Java还能火多久?
  20. 在UE4(Unreal Engine4)中安装 Quixel Bridge Megascans bridget插件

热门文章

  1. Oracle LAG()函数
  2. type/dtype/astype的作用
  3. 大数据领域经常听到ETL,那么什么是ETL
  4. PHP json 类型
  5. 电脑删除的视频怎么恢复?
  6. 播放器基础--OpenSL ES音频播放
  7. 点击预览或查看,报导航重复的问题
  8. 有哪些主动式电容笔值得推荐?平价主动式电容笔推荐
  9. python老鼠打洞问题_内网渗透-老鼠打洞之SSH隧道
  10. oracle数据库tns配置方法详解-转