Vue slot的用法

作者: 88b61f4ab233 | 来源:发表于2018-12-11 20:14 被阅读8次

    之前看官方文档,由于自己理解的偏差,不知道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>
    

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

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

    前端全栈学习交流圈: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至关重要.

    相关文章

      网友评论

        本文标题:Vue slot的用法

        本文链接:https://www.haomeiwen.com/subject/oeaehqtx.html