• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

详解Vue学习笔记入门篇之组件的内容分发(slot)

vue 搞代码 4年前 (2022-01-08) 23次浏览 已收录 0个评论

这篇文章主要介绍了详解Vue学习笔记入门篇之组件的内容分发(slot),具有一定的参考价值,感兴趣的小伙伴们可以参考一下

介绍

为了让组件可以组合,我们需要一种方式来混合父组件的内容与子组件自己的模板。这个过程被称为 内容分发 (或 “transclusion” 如果你熟悉 Angular)。Vue.js 实现了一个内容分发 API,使用特殊的 ‘slot’ 元素作为原始内容的插槽。

编译作用域

在深入内容分发 API 之前,我们先明确内容在哪个作用域里编译。假定模板为:

  {{ message }} 

message 应该绑定到父组件的数据,还是绑定到子组件的数据?答案是父组件。组件作用域简单地说是:

  1. 父组件模板的内容在父组件作用域内编译;
  2. 子组件模板的内容在子组件作用域内编译。

一个常见错误是试图在父组件模板内将一个指令绑定到子组件的属性/方法:

 <!-- 无效 -->

假定 someChildProperty 是子组件的属性,上例不会如预期那样工作。父组件模板不应该知道子组件的状态。

如果要绑定作用域内的指令到一个组件的根节点,你应当在组件自己的模板上做:

 Vue.component('child-component', { // 有效,因为是在正确的作用域内 template: '<div>Child</div>', data: function () { return { someChildProperty: true } } })

类似地,分发内容是在父作用域内编译。

单个slot

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

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

示例代码:

 <div id="app"> <h1>我是父组件的标题</h1> <p>初始内容1</p><p>初始内容2</p></div>
 Vue.component('my-component',{ template:` <div> <h2>我是子组件的标题</h2> 只有在没有要分发的内容是才出现。 <div> `, }) new Vue({ el:'#app' })

运行结果如下:

将html部分代码修改为以下代码:

 <div id="app"> <h1>我是父组件的标题</h1> </div>

则运行结果如下:

具名slot

‘slot’ 元素可以用一个特殊的属性 name 来配置如何分发内容。多个 slot 可以有不同的名字。具名 slot 将匹配内容片段中有对应 slot 特性的元素。

仍然可以有一个匿名 slot,它是默认 slot,作为找不到匹配的内容片段的备用插槽。如果没有默认的 slot,这些找不到匹配的内容片段将被抛弃。

如以下例子:

 <div id="app">  <h1>这是标题</h1><p>第一个段落</p><p>第二个段落</p><p>第三个段落</p><p>联系信息</p></div>
 Vue.component('my-component',{ template:` <div class="container"> <header> </header> <footer> </footer><div> `, }) new Vue({ el:'#app' })

运行结果如下:

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

作用域插槽

2.1.0新增

作用域插槽是一种特殊类型的插槽,用作使用一个 (能够传递数据到) 可重用模板替换已渲染元素。

在子组件中,只需将数据传递到插槽,就像你将 props 传递给组件一样。

示例代码:

 <div id="app">   <p>hello from parent</p><p>{{props.text}}</p></div>
 Vue.component('my-component',{ template:` <div class="child"> <div> `, props:['text'] }) new Vue({ el:'#app' })

运行结果:

在父级中,具有特殊属性 scope 的 元素必须存在,表示它是作用域插槽的模板。scope 的值对应一个临时变量名,此变量接收从子组件中传递的 props 对象。

作用域插槽更具代表性的用例是列表组件,允许组件自定义应该如何渲染列表每一项:

 <div id="app">   <li>{{props.text}}</li></div>
 Vue.component('my-component',{ template:` <ul> </ul> `, props:['text','items'] }) new Vue({ el:'#app', data:{ items:[ {text:'item1'}, {text:'item2'}, {<a style="color:transparent">本文来源gao($daima.com搞@代@#码$网</a>text:'item3'}, ] } })

作用域插槽也可以是具名的

运行结果:

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持gaodaima搞代码网

以上就是详解Vue学习笔记入门篇之组件的内容分发(slot)的详细内容,更多请关注gaodaima搞代码网其它相关文章!


搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:详解Vue学习笔记入门篇之组件的内容分发(slot)

喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址