vue具名插槽、作用域插槽的新写法

更新日期: 2019-10-23阅读: 2.7k标签: 插槽

具名插槽

自 2.6.0 起有所更新。已废弃的使用 slot attribute 的语法

但是我们有了新的语法,如下:

子组件 childCom:

<template id="childCom">
  <div>
    <!-- 具名插槽的针对于组件中不止一个插槽的情况下使用,使用方式,即:给每个插槽指定 name 属性,在使用的时候需要给标签设置 slot 属性,且属性值为 对应的 name 属性的属性值 -->
    <slot name='left'><span>左边</span></slot> <!--给每个插槽命名,插槽中间是默认内容-->
    <slot name='center'><span>中间</span></slot>
    <slot name='right'><span>右边</span></slot>
  </div>
</template>

父组件 app:

<div id="app">
  <cpn></cpn>
  <!-- 2.6.0更新后的插槽使用方式发生了变化 -->
  <!-- 区别在于调动的时候是使用 v-slot:具体名称,而不是定义一个 slot='具体名称' 这样的属性 -->
  <cpn>
   <!-- 注意:2.6.0 之后的这个写法中,v-slot:具体名称 只能写在 template 标签中,而废弃的写法可以写在某个具体的标签上面 -->
   <template v-slot:center>  <!-- 指明使用的是哪个插槽 -->
      用户名:<input type="text">
   </template>
  </cpn>
</div>

效果图:


注意: v-slot 只能添加在 template 上


作用域插槽

有时让插槽内容能够访问子组件中才有的数据是很有用的。但是由于子组件的作用域在子组件,而父组件的作用域在父组件,这样一来,父组件就访问不到子组件的信息了,但是我们又不想用$emit发送事件去传递信息,这个时候可以用作用域插槽来实现。注意:你不要以为这又是父传子的一种方式,因为这种方法仅限于在使用插槽的时候才有用,话不多说,看代码

vm实例:

<script>
  var vm = new vue({
    el: '#app',
    data: {},
    methods: {},
    components: {
      cpn: {
        template: '#cpn',
        data() {
          return {
            list: ['coderlyl', 'tom' , 'mack']
          }
        },
      }
    }
  });
</script>

子组件 childCom:

<template id="cpn">
  <div>
    <slot :coderlyl='list'>  
    <!--list是子组件data中的数据,coderlyl是自己命名的变量,前面还有v-bind绑定-->
      <ul>
        <li v-for="(item, index) in list" :key="index">{{item}}</li>
      </ul>
    </slot>
  </div>
</template>

父组件 app:

<div id="app">
  <cpn></cpn>

  <cpn>
    <template v-slot='lyl'>  <!--这里的lyl也是自己命名的-->
      <span>{{lyl.coderlyl.join('--')}}</span>
    </template>
  </cpn>
</div>

效果图:



处理边界情况

$root 用来访问根组件
$parent 用来从一个子组件访问父组件的实例
ref 和 $refs 的用法

在组件上面使用 ref 这个属性绑定,属性值自取,然后就可以通过 $refs.属性名 这种方式去获取到指定组件的实例了。

其实不仅仅是组件能够使用 ref ,标签元素也能使用。


依赖注入

现在我们有一个需求,如果我们存在多个组件嵌套的,然后现在其中某一个组件想访问其曾祖父组件的方法,那么使用上面两种方式都是不可取的,这个时候官方提供了 provide 和 inject 这两个属性来解决这个问题。

provide 允许我们指定想要提供给后代组件的数据/方法,且该属性是一个方法,返回一个对象,键名就是我们要传到后代组件的标志

然后在任何后代组件里,我们都可以使用 inject 选项来接收指定的我们想要添加在这个实例上的属性。该属性是一个数组类型,跟 props 的数组语法类似

说到这里,有的人可能会觉得这不就是跟 props 差不多嘛。没错,它确实差不多,但是还是有区别的,比如,祖先元素不需要知道哪些后代组件使用它提供的属性;其次,后代组件也不需要知道被注入的属性来自哪里

代码如下:

父组件:

<div id="app">
  <child-com></child-com>
</div>

<template id="childCom">
  <div>
    <span>我是子组件</span>
    <grand-com></grand-com>
  </div>
</template>

<template id="grandCom">
  <div>
    <span>我是孙子组件</span>
    <button @click='btnClick'>孙子组件按钮</button>
    <h2>{{mess}}</h2>
  </div>
</template>

<script>
  const vm = new Vue({
    el: '#app',      //  父组件
    methods: {
      sendMessage() {
        return '我发送了信息'
      }
    },
    provide() {  //  注意这里的 provide属性
      return {
        sendMess: this.sendMessage()  //  提供给后代了一个方法
      }
    },
    components: {
      childCom: {
        template: '#childCom',   //  子组件
        components: {
          grandCom: {
            template: '#grandCom',   //  孙子组件
            inject: ['sendMess'],    //  注意这里的 inject属性
            data() {
              return {
                mess: ''
              }
            },
            methods: {
              btnClick() {
                this.mess = this.sendMess //  孙子组件用了这个方法
              }
            },
          }
        }
      }
    }
  })
</script>

效果图:



链接: https://fly63.com/article/detial/7352

Vue 技能进阶:使用设计模式写出优雅的前端代码

本文针对 Vue 中如何控制组件子树之外的东西,探讨了四种解决方案,并展示了每种解决方案的优缺点。希望读者能从中受到启发。问你个问题,以前你可能从来没想过:有没有办法从子组件填充父组件插槽?

vue插槽slot和slot-scope

插槽我对他的理解就是父组件的东西插到子组件的<slot></slot>里面,也不知道这样理解对不对,方便自己记忆;作用域插槽我对他的理解就是数据在子组件里面,父组件可以用

一个案例搞懂 Vue.js 的作用域插槽

作用域插槽是 Vue.js 中一个很有用的特性,可以显著提高组件的通用性和可复用性。问题在于,它实在不太好理解。尝试搞清楚父子作用域之间错综复杂的关系,其痛苦程度不亚于求解一个棘手的数学方程。

Vue.js 中的无渲染行为插槽

在本文中我们讨论 Vue 中的无渲染插槽模式能够帮助解决哪些问题。在 Vue.js 2.3.0 中引入的作用域插槽显著提高了组件的可重用性。无渲染组件模式应运而生,解决了提供可重用行为和可插入表示的问题。

深入了解Vue.js的作用域插槽

作用域槽是Vue.js的一个有用特性,它可以使组件更加通用和可重用。唯一的问题是它们很难理解!试着让你的头在父母和孩子的范围内交织,就像解决一个棘手的数学方程。

Vue 2.60 中, 插槽新增的v-slot

注意v-slot只能添加在<template>上(只有一种例外情况),这一点和已经废弃的slotattribute不同。有时让插槽内容能够访问子组件中才有的数据是很有用的。例如,设想一个带有如下模板的<current-user>组件:

如何通过带有Vue插槽的组件传递HTML内容

这篇文章将向您介绍如何使用Vue插槽在Vue.js中将数据从父组件传递到子组件。这篇文章适合所有阶段的开发人员(包括初学者)。

如何使用Vue中的嵌套插槽(包括作用域插槽)

最近我弄清楚了如何递归地实现嵌套插槽,包括如何使用作用域插槽来实现。起因是我想看看是否可以构建一个复制v-for指令但仅使用template组件。

在Vue中,如何从插槽中发出数据

我们知道使用作用域插槽可以将数据传递到插槽中,但是如何从插槽传回来呢?将一个方法传递到我们的插槽中,然后在插槽中调用该方法。 我信无法发出事件

vue中插槽slot的使用

官方解释:Vue 实现了一套内容分发的 API,将 <slot> 元素作为承载分发内容的出口。插槽就是子组件中的提供给父组件使用的一个占位符

点击更多...

内容以共享、参考、研究为目的,不存在任何商业目的。其版权属原作者所有,如有侵权或违规,请与小编联系!情况属实本人将予以删除!