Vue slot用法(小结)


Posted in Javascript onOctober 22, 2018

之前看官方文档,由于自己理解的偏差,不知道slot是干嘛的,看到小标题,使用Slot分发内容,就以为 是要往下派发内容。然后就没有理解插槽的概念。其实说白了,使用slot就是先圈一块地,将来可能种花种菜,也有可能在这块地上建房子。然而slot可以以一当十,可以插入很多东西。不知明白否?

由于项目经验有限,这篇我就先跟着官网的知识点走,当然会加入自己的部分项目代码。

关于slot是这样说的,

除非子组件模板包含至少一个 <slot> 插口,否则父组件的内容将会被丢弃。当子组件模板只有一个没有属性的 slot 时,父组件整个内容片段将插入到 slot 所在的 DOM 位置,并替换掉 slot 标签本身。

最初在 <slot> 标签中的任何内容都被视为备用内容。备用内容在子组件的作用域内编译,并且只有在宿主元素为空,且没有要插入的内容时才显示备用内容。

单个 Slot

在子组件内使用特殊的<slot>元素就可以为这个子组件添加一个 slot (插槽),在父组件模板里,插入在子组件标签内的所有内容将替代子组件的<slot>标签及它的内容.示例代码如下:

<!DOCTYPE html>
<html>
<head>
  <meta charset="utf-8">
  <title>示例</title>

</head>
<body>

  <div id="app">
    <child-component>
      <p>分发的内容</p>
      <p>更多分发的内容</p>
    </child-component>
  </div>
  
  <script src="https://unpkg.com/vue/dist/vue.min.js"></script>

  <script>

    Vue.component('child-component', {
      template: '\
      <div>\
        <slot>\
          <p>如果父组件没用插入内容,我将作为默认出现</p>\
        </slot>\
      </div>'
    });

    var app = new Vue({
      el: '#app'
    })

  </script>

</body>
</html>

子组件 child-component 的模板内定义一个 <slot> 元素,并且用一个 <p> 作为默认的内容,在父组件没有使用 slot 时,会渲染这段默认的文本;如果写入了 slot ,那就会替换整个 <slot>.所以上列渲染后的结果为:

<div id="app">
   <div>
    <p>分发的内容</p>
    <p>更多分发的内容</p>
  </div>
</div>

注意:子组件<slot>内的备用内容,它的作用域时子组件本身.

具名 Slot

给 <slot> 元素指定一个 name 后可以分发多个内容,具名 Slot 可以与单个 Slot 共存,例如下面的示例:

<!DOCTYPE html>
<html>
<head>
  <meta charset="utf-8">
  <title>示例</title>

</head>
<body>

  <div id="app">
    <child-component>
      <h2 slot="header">标题</h2>
      <p>正文内容</p>
      <p>更多正文内容</p>
      <div slot="footer">底部信息</div>
    </child-component>
  </div>
  
  <script src="https://unpkg.com/vue/dist/vue.min.js"></script>

  <script>

    Vue.component('child-component', {
      template: '\
      <div class="component">\
        <div class="header">\
          <slot name="header"></slot>\
        </div>\
        <div class="main">\
          <slot></slot>\
        </div>\
        <div class="footer">\
          <slot name="footer"></slot>\
        </div>\
      </div>'
    });

    var app = new Vue({
      el: '#app'
    })

  </script>

</body>
</html>

子组件内声明了3个 <slot> 元素,其中在<div class="main">内的<slot> 没用使用 name 特性,它将作为默认 slot 出现,父组件没有使用 slot 特性的元素与内容都将出现在这里.

如果没有指定默认的匿名 slot, 父组件内多余的内容片段都将被抛弃.

上例最终渲染后的结果为:

<div id="app">
    <div class="container">
      <div class="header">
        <h2>标题</h2>
      </div>
      <div class="main">
        <p>正文内容</p>
        <p>更多的正文内容</p>
      </div>
      <div class="footer">
        <div>底部信息</div>
      </div>
    </div>
  </div>

在组合使用组件时,内容分发API至关重要.

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
JS实现匀速运动的代码实例
Nov 29 Javascript
使用AngularJS对路由进行安全性处理的方法
Jun 18 Javascript
Bootstrap中的Panel和Table全面解析
Jun 13 Javascript
AngularJS基础 ng-repeat 指令简单示例
Aug 03 Javascript
Vue.js双向绑定实现原理详解
Dec 22 Javascript
js实现倒计时关键代码
May 05 Javascript
详解React-Router中Url参数改变页面不刷新的解决办法
May 08 Javascript
深入剖析Node.js cluster模块
May 23 Javascript
jquery实现联想词搜索框和搜索结果分页的示例
Oct 10 jQuery
Node.js使用supervisor进行开发中调试的方法
Mar 26 Javascript
使用webpack4编译并压缩ES6代码的方法示例
Apr 24 Javascript
微信小程序实现搜索功能
Mar 10 Javascript
TypeScript基础入门教程之三重斜线指令详解
Oct 22 #Javascript
vue项目中使用Hbuilder打包app 设置沉浸式状态栏的方法
Oct 22 #Javascript
vue-cli项目中使用echarts图表实例
Oct 22 #Javascript
vue使用echarts图表的详细方法
Oct 22 #Javascript
在vue中使用echarts图表实例代码详解
Oct 22 #Javascript
Koa 使用小技巧(小结)
Oct 22 #Javascript
在js代码拼接dom对象到页面上的模板总结
Oct 21 #Javascript
You might like
用在PHP里的JS打印函数
2006/10/09 PHP
php反弹shell实现代码
2009/04/22 PHP
PhpStorm terminal无法输入命令的解决方法
2016/10/09 PHP
PHP Socket网络操作类定义与用法示例
2017/08/30 PHP
PHP下 Mongodb 连接远程数据库的实例代码
2017/08/30 PHP
php经典趣味算法实例代码
2020/01/21 PHP
xml分页+ajax请求数据源+dom取结果实例代码
2008/10/31 Javascript
javascript 动态调整图片尺寸实现代码
2009/12/28 Javascript
JS中Iframe之间传值及子页面与父页面应用
2013/03/11 Javascript
js捕获鼠标右键菜单中的粘帖事件实现代码
2013/04/01 Javascript
JS正则表达式修饰符global(/g)用法分析
2016/12/27 Javascript
微信小程序 实战程序简易新闻的制作
2017/01/09 Javascript
react-native DatePicker日期选择组件的实现代码
2017/09/12 Javascript
Vue结合后台导入导出Excel问题详解
2019/02/19 Javascript
微信小程序登录对接Django后端实现JWT方式验证登录详解
2019/07/29 Javascript
layui原生表单验证的实例
2019/09/09 Javascript
js 根据对象数组中的属性进行排序实现代码
2019/09/12 Javascript
Python中replace方法实例分析
2014/08/20 Python
Python3实现并发检验代理池地址的方法
2016/09/18 Python
scrapy爬虫实例分享
2017/12/28 Python
Python实现的端口扫描功能示例
2018/04/08 Python
浅析python表达式4+0.5值的数据类型
2020/02/26 Python
CSS3实现文本垂直排列的方法
2018/07/10 HTML / CSS
欧洲最大的婴幼儿服装及内衣公司:Petit Bateau(小帆船)
2016/08/16 全球购物
Get The Label中文官网:英国运动时尚购物平台
2017/04/19 全球购物
私有程序集与共享程序集有什么区别
2013/04/05 面试题
酒店销售主管岗位职责
2014/01/04 职场文书
简短证婚人证婚词
2014/01/09 职场文书
市三好学生主要事迹
2014/01/28 职场文书
全国道德模范事迹
2014/02/01 职场文书
小学生感恩父母演讲稿
2014/08/28 职场文书
2014年留守儿童工作总结
2014/12/10 职场文书
2015年办公室工作总结范文
2015/03/31 职场文书
大学毕业典礼致辞
2015/07/29 职场文书
MySQL安装后默认自带数据库的作用详解
2021/04/27 MySQL
PYTHON使用Matplotlib去实现各种条形图的绘制
2022/03/22 Python