美文网首页
slot插槽

slot插槽

作者: w_wx_x | 来源:发表于2018-12-12 16:31 被阅读1次

默认插槽:未命名的单个插槽
     若没有包含<slot>元素,则传入的任何内容都会被抛弃

<!-- Nav组件 -->
<template>
   <a :href="url" class="nav-link">
    <slot></slot>
  </a>
</template>
<script>
export default{
  name:'Nav'
}
</script>


<!-- Nav组件的调用 -->
<nav url="/profile">
  <span class="fa fa-user">111</span>
</nav>


<!-- 生成的html -->
<a href="/profile" class="nav-link">
  <span class="fa fa-user">111</span>
</a>

具名插槽:多个插槽
     可以保留一个未命名插槽,是默认插槽,作为所有未匹配到插槽的内容的统一出口

<!-- BaseLayout组件的定义 -->
<template>
  <div class="container">
    <header>
      <slot name="header"></slot>
    </header>
    <main>
      <slot></slot>
    </main>
    <footer>
      <slot name="footer"></slot>
    </footer>
</div>
</template>
<script>
export default{
  name:'BaseLayout'
}
</script>


<!-- BaseLayout组件的调用 -->
<base-layout>
  <!-- 也可以直接将slot放在元素上,如:
    <h1 slot="header">header</h1>
   -->
  <template slot="header">
    <h1>header</h1>
  </template>
  <p>A paragraph for the main content.</p>
  <p>And another one.</p>
  <template slot="footer">
    <h1>footer</h1>
  </template>
</base-layout>

插槽默认内容:插槽里面有默认内容,若为这个插槽提供了内容,则默认内容将被替换掉

<button>
  <slot>Submit</slot>
</button>

作用域
   父组件模板的东西会在父级作用域编译
   子组件模板的东西会在子级作用域编译

<navigation-link url="/profile">
  <!--
    此插槽不能访问<navigation-link>的作用域
  -->
  Logged in as {{ user.name }}
</navigation-link>

slot-scope:插槽作用域
     不再限制在<template>元素上使用,可以用在插槽内的任何元素或组件上
     会使作用域插槽变得更干净

<!-- TodoList组件 -->
<ul>
  <li v-for="todo in todos" :key="todo.id">
    <slot :todo="todo">
      {{todo.text}}
    </slot>
  </li>
</ul>

<!-- TodoList组件的调用 -->
<todo-list :todos="todos">
  <template slot-scope="slotProps">
    <span v-if="slotProps.todo.isComplete">Y</span>
    {{slotProps.todo.text}}
  </template>
</todo-list>

相关文章

  • 插槽

    默认插槽: 具名插槽:slot name='footer' 作用域插槽:v-slot===slot-scope 默...

  • 2-6 vue 匿名插槽-slot

    匿名插槽-slot Slot插槽 —— 实现内容分发 什么是slot?slot的意思是插槽,其目的在于让组件的可扩...

  • Vue之深入理解插槽—slot, slot-scope, v-s

    Vue 2.6.0 以前Vue 2.6.0 以后具名插槽 slot具名插槽 v-slot作用域插槽 slot-sc...

  • 插槽

    插槽的基础使用,

  • 插槽slot

    插槽,占位符slot具名插槽,指定占位符slot、name作用域插槽,子组件占位符向父组件占位符通信。slot、s...

  • vue slot匿名插槽 / 具名插槽 / 作用域插槽

    slot 匿名插槽 slot 具名插槽 应用场景 slot 作用域插槽: 在父组件中可以获得子组件的数据,并在父组...

  • vue插槽

    vue插槽slot的理解与使用 vue slot插槽的使用介绍及总结

  • 在vue中使用插槽

    slot 插槽

  • vue slot插槽

    v-slot 插槽的用法: 单个slot内容时: 子组件: 父组件: 多个slot内容时(具名插槽): 子组件: ...

  • vue插槽slot详解

    插槽分类:具名插槽与作用域插槽。在新版中(2.6.0)统一都叫v-slot指令,老版中称之为slot与slot-s...

网友评论

      本文标题:slot插槽

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