zoukankan      html  css  js  c++  java
  • Vue插槽

    插槽内容

    Vue实现一套内容分发的API, 这套API基于当前的web组件规范草案,将<slot>元素作为承载分发内容的出口。

    
    &lt;navigation-link url="/profile"&gt;
        Your Profile
    &lt;/navigation-link&gt;
    

    然后在<navigation-link>的模板中可能会写为:

    
    &lt;a :href="url" class="nav-link"&gt;
        &lt;slot&gt;&lt;/slot&gt;
    &lt;/a&gt;
    

    当组件渲染的时候,这个<slot>元素将会被"Yourt Profile"替换。插槽可以包括任何模板代码,包括HTML:

    
    &lt;navigation-link url="/profile"&gt;
        &lt;span class="fa fa-user"&gt;&lt;/span&gt;
        Your Profile
    &lt;/navigation-link&gt;
    

    甚至其他的组件:

    
    &lt;navigation-link url="/profile"&gt;
        &lt;font-awesome-icon name="user"&gt;&lt;/font-awesome-icon&gt;
        Your Profile
    &lt;/navigation-link&gt;
    

    如果<navigation-link>没有包含一个<slot>元素,则任何传入它的内容都会被抛弃。

    具名插槽

    有些时候我们需要多个插槽,例如:

    
    &lt;div&gt;
        &lt;header&gt;我们希望把页头放这里&lt;/header&gt;
        &lt;main&gt;我们希望把主要内容放这里&lt;/main&gt;
        &lt;footer&gt;我们希望把页脚放这里&lt;/footer&gt;
    &lt;/div&gt;
    

    对于这种情况,<slot>元素有一个特殊的特性:name。这个特性可以用来定义额外的插槽:

    
    &lt;div class="container"&gt;
        &lt;header&gt;
            &lt;slot name="header"&gt;&lt;/slot&gt;
        &lt;/header&gt;
        &lt;main&gt;
            &lt;slot&gt;&lt;/slot&gt;
        &lt;/main&gt;
        &lt;footer&gt;
            &lt;slot name="footer"&gt;&lt;/slot&gt;
        &lt;/footer&gt;
    &lt;/div&gt;
    

    在向具名插槽提供内容的时候,我们可以在一个父组件的<template>元素上使用slot特性:

    
    &lt;base-layout&gt;
        &lt;template slot="header"&gt;
            &lt;h1&gt;Here might be a page title&lt;/h1&gt;
        &lt;/template&gt;
        &lt;p&gt;A paragraph for the main content&lt;/p&gt;
        &lt;p&gt;And another one&lt;/p&gt;
        &lt;template slot="footer"&gt;
            &lt;p&gt;here is some contact info&lt;/p&gt;
        &lt;/template&gt;
    &lt;/base-layout&gt;
    

    另一种slot特性的用法是直接用在一个普通元素上:

    
    &lt;base-layout&gt;
        &lt;h1 slot="header"&gt;Here might be a page title&lt;/h1&gt;
        
        &lt;p&gt;A paragraph for the main content&lt;/p&gt;
        &lt;p&gt;And another one&lt;/p&gt;
        
        &lt;p slot="footer"&gt;Here is some contact info&lt;/p&gt;
    &lt;/base-layout&gt;
    

    我们还是可以保留一个未命名插槽,这个插槽是默认插槽,也就是说它会作为所有未匹配到插槽的内容的统一出口,上述两个示例渲染出来的HTML都将会是:

    
    &lt;div class="container"&gt;
      &lt;header&gt;
        &lt;h1&gt;Here might be a page title&lt;/h1&gt;
      &lt;/header&gt;
      &lt;main&gt;
        &lt;p&gt;A paragraph for the main content.&lt;/p&gt;
        &lt;p&gt;And another one.&lt;/p&gt;
      &lt;/main&gt;
      &lt;footer&gt;
        &lt;p&gt;Here's some contact info&lt;/p&gt;
      &lt;/footer&gt;
    &lt;/div&gt;
    

    插槽的默认内容

    有的时候为插槽提供默认内容是很有用的。例如,一个<submit-button>组件可能希望这个按钮的默认内容是"Submit",但是同时允许用户覆盖"Save","Upload"或者别的内容。

    你可以在组件模板里的<slot>标签内部指定默认的内容来做到这一点。

    
    &lt;button type="submit"&gt;
        &lt;slot&gt;Submit&lt;/slot&gt;
    &lt;/button&gt;
    

    如果父组件为这个插槽提供内容,则默认内容会被替换。

    编译作用域

    当你想在插槽内使用数据时,例如:

    
    &lt;navigation-link url="/profile"&gt;
        Logged in as {{ user.name }}
    &lt;/navigation-link&gt;
    

    该插槽可以访问跟这个模板的其他地方相同的实例属性(也就是说作用域相同)。但这个插槽不能访问<navigation-link>的作用域。例如尝试访问URL是不会工作的。牢记:

    
    &gt;**父组件模板的所有东西都会在父级作用域内编译;子组件的模板的所有东西都会在子级作用域内编译。**
    

    作用域插槽

    有时候你希望提供的组件带有一个可从子组件获取数据的可复用的插槽:

    
    &lt;ul&gt;
        &lt;li v-for="todo in todos" v-bind="todo.id"&gt;
            {{ todo.text }}
        &lt;/li&gt;
    &lt;/ul&gt;
    

    但是在我们应用的某些部分,我们希望每个独立的代办项渲染出和todo.text不太一样的东西。这也是作用域插槽的用武之地。

    为了让这个特性成为可能,你需要做的全部事情就是将代办项内容包裹在一个<slot>元素上,然后将所有和其上下文有关的数据传递给这个插槽:在这个例子中,这个数据是todo对象:

    
    &lt;ul&gt;
        &lt;li v-for="todo in todos" :key="todo.id"&gt;
            &lt;slot :todo="todo"&gt;{{ todo.text }}&lt;/slot&gt;
        &lt;/li&gt;
    &lt;/ul&gt;
    

    现在当我们使用<todo-list>组件的适合,我们可以选择为代码项定义一个不一样的<template>作为替代方案,并且可以通过slot-scope特性从子组件获取数据:

    
    &lt;todo-list :todos="todos"&gt;
        &lt;!-- 将 `slotProps` 定义为插槽作用域的名字 --&gt;
        &lt;template slot-scope="slotProps"&gt;
            &lt;!-- 为待办项自定义一个模板,--&gt;
            &lt;!-- 通过 `slotProps` 定制每个待办项。--&gt;
            &lt;span v-if="slotProps.todo.is"&gt;good&lt;/span&gt;
            {{ slotProps.todo.text }}
        &lt;/template&gt;
    &lt;/todo-list&gt;
    

    解构 slot-scope
    如果一个JavaScript表达式在一个函数定义的参数位置有效,那么这个表达式实际上就可以被slot-scope接受。也就是说你可以在支持的环境下,在这些表达式中使用ES2015解构语法。

    
    &lt;todo-list :todos="todos"&gt;
        &lt;template slot-scope="{ todo }"&gt;
        &lt;span v-if="todo.isComplete"&gt;✓&lt;/span&gt;
        {{ todo.text }}
      &lt;/template&gt;
    &lt;/todo-list&gt;
    

    来源:https://segmentfault.com/a/1190000016886400

  • 相关阅读:
    Docker外包团队 2019年3月更新 企业如何使用Docker
    2019年3月更新 技术分享 WPF基本界面制作
    Winform外包团队 项目案例展示
    WinForm外包公司 WInform外包项目监控案例展示
    H5外包团队 android视频压缩,使用ffmpeg方案
    为什么选择Go语言 GO语言都能做什么产品
    Go外包 Go语言外包 Golang外包商 浅谈Go的全局变量和生命周期
    SaaS外包商 承接SaaS产品开发 Software-as-a-Service(软件即服务)
    北京U3D外包团队 UE4红军抗战案例 Unity3D红军抗战案例 UE4下载和安装虚幻4游戏引擎
    Unity3D外包 团队更新一下UE4和Unity3D案例
  • 原文地址:https://www.cnblogs.com/lovellll/p/10126095.html
Copyright © 2011-2022 走看看