Vue slot的用法

以前看官方文档,因为本身理解的误差,不知道slot是干吗的,看到小标题,使用Slot分发内容,就觉得 是要往下派发内容。而后就没有理解插槽的概念。其实说白了,使用slot就是先圈一块地,未来可能种花种菜,也有可能在这块地上建房子。然而slot能够以一当十,能够插入不少东西。不知明白否?html

因为项目经验有限,这篇我就先跟着官网的知识点走,固然会加入本身的部分项目代码。前端

关于slot是这样说的,vue

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

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

单个 Slotcode

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

<!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>

前端全栈学习交流圈:866109386,面向1-3经验年前端开发人员,帮助突破技术瓶颈,提高思惟能力,群内有大量PDF可供自取,更有干货实战项目视频进群免费领取。视频

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

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

注意:子组件<slot>内的备用内容,它的做用域时子组件自己.ip

具名 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>

前端全栈学习交流圈:866109386,面向1-3经验年前端开发人员,帮助突破技术瓶颈,提高思惟能力,群内有大量PDF可供自取,更有干货实战项目视频进群免费领取。

子组件内声明了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相当重要.

相关文章
相关标签/搜索