Vue学习—slot

  1. 作为Vue特殊属性的 slot 是用于标记往哪个具名插槽中插入子组件内容。slot-scope用于将元素或组件表示为作用域插槽。特性的值应该是可以出现在函数签名的参数位置的合法的 JavaScript 表达式。这意味着在支持的环境中,你还可以在表达式中使用 ES2015 解构。它在 2.5.0+ 中替代了 scope。此属性不支持动态绑定。
    < body>
    < h1>slot</ h1>
    < div id= "app">
    < goods v-for= "abc in goods">
    < span slot= 'name'>{{abc.name}}</ span>
    < span slot= 'num'>{{abc.num}}</ span>
    </ goods>
    </ div>
    < template id= "demo">
    < div>
    < p>
    名称:
    < slot name= 'name'></ slot>
    数量:
    < slot name= 'num'></ slot>
    </ p>
    </ div>
    </ template>
    < script>
    goods = {
    template: "#demo"
    }
    var vm = new Vue({
    el: "#app",
    data: {
    goods: [{
    name: 'pen',
    num: 10
    },
    {
    name: 'car',
    num: 1
    }
    ]
    },
    components: {
    "goods": goods
    }

    })
    </ script>
    </ body>
  2. 使用插槽分发内容:在使用组件时,我们常常要像这样组合它们
    < app>
    < app-header></ app-header>
    < app-footer></ app-footer>
    </ app>
    注意两点:首先<app> 组件不知道它会收到什么内容。这是由使用 <app> 的父组件决定的;其次<app> 组件很可能有它自己的模板。所以为了让组件可以组合,我们需要一种方式来混合父组件的内容与子组件自己的模板。这个过程被称为内容分发 。Vue.js 实现了一个内容分发 API,参照了当前 Web Components 规范草案,使用特殊的 <slot> 元素作为原始内容的插槽
  3. 使用插槽分发内容—编译作用域:在深入内容分发 API 之前,我们先明确内容在哪个作用域里编译。假定模板为:
    < child-component>
    {{ message }}
    </ child-component>
    message 应该绑定到父组件的数据,还是绑定到子组件的数据?答案是父组件。组件作用域简单地说是:父组件模板的内容在父组件作用域内编译;子组件模板的内容在子组件作用域内编译。
    一个常见错误是试图在父组件模板内将一个指令绑定到子组件的属性/方法:
    <!-- 无效 -->
    < child-component v-show="someChildProperty"></ child-component>
    假定 someChildProperty 是子组件的属性,上例不会如预期那样工作。父组件模板并不感知子组件的状态。如果要绑定子组件作用域内的指令到一个组件的根节点,你应当在子组件自己的模板里做:
    Vue. component( 'child-component', {
    // 有效,因为是在正确的作用域内
    template: '<div v-show="someChildProperty">Child</div>',
    data: function () {
    return {
    someChildProperty: true
    }
    }
    })
    类似地,被分发的内容会在父作用域内编译。
  4. 使用插槽分发内容—单个插槽:除非子组件模板包含至少一个 <slot> 插口,否则父组件的内容将会被丢弃。当子组件模板只有一个没有属性的插槽时,父组件传入的整个内容片段将插入到插槽所在的 DOM 位置,并替换掉插槽标签本身。
           最初在 <slot> 标签中的任何内容都被视为备用内容。备用内容在子组件的作用域内编译,并且只有在宿主元素为空,且没有要插入的内容时才显示备用内容。
    假定 my-component 组件有如下模板:
    < h2>我是子组件的标题</ h2>
    < slot>
    只有在没有要分发的内容时才会显示。
    </ slot>

    父组件模板:

    < div>
    < h1>我是父组件的标题</ h1>
    < my-component>
    < p>这是一些初始内容</ p>
    < p>这是更多的初始内容</ p>
    </ my-component>
    </ div>

    渲染结果为:

    < div>
    < h1>我是父组件的标题</ h1>
    < div>
    < h2>我是子组件的标题</ h2>
    < p>这是一些初始内容</ p>
    < p>这是更多的初始内容</ p>
    </ div>
    </ div>

  5. 使用插槽分发内容—具名插槽:<slot> 元素可以用一个特殊的特性 name 来进一步配置如何分发内容。多个插槽可以有不同的名字。具名插槽将匹配内容片段中有对应 slot 特性的元素。仍然可以有一个匿名插槽,它是默认插槽,作为找不到匹配的内容片段的备用插槽。如果没有默认插槽,这些找不到匹配的内容片段将被抛弃。

    例如,假定我们有一个 app-layout 组件,它的模板为:

    < div class= "container">
    < header>
    < slot name= "header"></ slot>
    </ header>
    < main>
    < slot></ slot>
    </ main>
    < footer>
    < slot name= "footer"></ slot>
    </ footer>
    </ div>

    父组件模板:

    < app-layout>
    < h1 slot= "header">这里可能是一个页面标题</ h1>

    < p>主要内容的一个段落。</ p>
    < p>另一个主要段落。</ p>

    < p slot= "footer">这里有一些联系信息</ p>
    </ app-layout>

    渲染结果为:

    < div class= "container">
    < header>
    < h1>这里可能是一个页面标题</ h1>
    </ header>
    < main>
    < p>主要内容的一个段落。</ p>
    < p>另一个主要段落。</ p>
    </ main>
    < footer>
    < p>这里有一些联系信息</ p>
    </ footer>
    </ div>

    在设计组合使用的组件时,内容分发 API 是非常有用的机制。

  6. 使用插槽分发内容—作用域插槽:作用域插槽是一种特殊类型的插槽,用作一个 (能被传递数据的) 可重用模板,来代替已经渲染好的元素。在子组件中,只需将数据传递到插槽,就像你将 prop 传递给组件一样:

    < div class= "child">
    < slot text= "hello from child"></ slot>
    </ div>
    在父级中,具有特殊特性 slot-scope 的 <template> 元素必须存在,表示它是作用域插槽的模板。slot-scope 的值将被用作一个临时变量名,此变量接收从子组件传递过来的 prop 对象:
    < div class= "parent">
    < child>
    < template slot-scope= "props">
    < span>hello from parent</ span>
    < span>{{ props.text }}</ span>
    </ template>
    </ child>
    </ div>
    如果我们渲染上述模板,得到的输出会是:
    < div class= "parent">
    < div class= "child">
    < span>hello from parent</ span>
    < span>hello from child</ span>
    </ div>
    </ div>
    在 2.5.0+,slot-scope 能被用在任意元素或组件中而不再局限于 <template>。作用域插槽更典型的用例是在列表组件中,允许使用者自定义如何渲染列表的每一项:
    < my-awesome-list :items="items">
    <!-- 作用域插槽也可以是具名的 -->
    < li
    slot= "item"
    slot-scope= "props"
    class= "my-fancy-item">
    {{ props.text }}
    </ li>
    </ my-awesome-list>
    列表组件的模板:
    < ul>
    < slot name= "item"
    v-for="item in items"
    :text="item.text">
    <!-- 这里写入备用内容 -->
    </ slot>
    </ ul>
    slot-scope 的值实际上是一个可以出现在函数签名参数位置的合法的 JavaScript 表达式。这意味着在受支持的环境 (单文件组件或现代浏览器) 中,您还可以在表达式中使用 ES2015 解构:
    < child>
    < span slot-scope= "{ text }">{{ text }}</ span>
    </ child>

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值