zoukankan      html  css  js  c++  java
  • Vue: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至关重要.



    作者:一叶扁舟丶
    链接:https://www.jianshu.com/p/559332a9c123
    来源:简书
    著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。
  • 相关阅读:
    vue生命周期简介和钩子函数
    vue.js 笔记
    vue-cli安装以及搭建vue项目详细步骤
    nodejs 报错
    线程池 一 ThreadPoolExecutor
    JUC 一 线程池
    线程八锁
    JUC 一 ReentrantReadWriteLock
    JUC 一 ReentrantLock 可重入锁
    JUC 一 CountDownLatch(闭锁)
  • 原文地址:https://www.cnblogs.com/zjw2004112/p/12408639.html
Copyright © 2011-2022 走看看