返回顶部
首页 > 资讯 > 精选 >vue中的slot与slot-scope实例分析
  • 769
分享到

vue中的slot与slot-scope实例分析

2023-06-27 10:06:23 769人浏览 薄情痞子
摘要

本篇内容主要讲解“Vue中的slot与slot-scope实例分析”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“vue中的slot与slot-scope实例分析”吧!写在前面vue 中关于插槽的

本篇内容主要讲解“Vue中的slot与slot-scope实例分析”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“vue中的slot与slot-scope实例分析”吧!

写在前面

vue 中关于插槽的文档说明很短,语言又写的很凝练,再加上其和 methodsdatacomputed 等常用选项使用频率、使用先后上的差别,这就有可能造成初次接触插槽的开发者容易产生“算了吧,回头再学,反正已经可以写基础组件了”,于是就关闭了 vue 说明文档。

实际上,插槽的概念很简单,下面通过分三部分来讲。这个部分也是按照 vue 说明文档的顺序来写的。

进入三部分之前,先让还没接触过插槽的同学对什么是插槽有一个简单的概念:插槽,也就是 slot,是组件的一块 html 模板,这块模板显示不显示、以及怎样显示由父组件来决定。 实际上,一个 slot 最核心的两个问题这里就点出来了,是显示不显示和怎样显示。

由于插槽是一块模板,所以,对于任何一个组件,从模板种类的角度来分,其实都可以分为非插槽模板和插槽模板两大类。非插槽模板指的是 html 模板,指的是‘divspanultable’这些,非插槽模板的显示与隐藏以及怎样显示由插件自身控制;插槽模板是 slot,它是一个空壳子,因为它显示与隐藏以及最后用什么样的 html 模板显示由父组件控制。但是插槽显示的位置确由子组件自身决定,slot 写在组件 template 的哪块,父组件传过来的模板将来就显示在哪块。

单个插槽 | 默认插槽 | 匿名插槽

首先是单个插槽,单个插槽是 vue 的官方叫法,但是其实也可以叫它默认插槽,或者与具名插槽相对,我们可以叫它匿名插槽。因为它不用设置 name 属性。

单个插槽可以放置在组件的任意位置,但是就像它的名字一样,一个组件中只能有一个该类插槽。相对应的,具名插槽就可以有很多个,只要名字(name 属性)不同就可以了。

下面通过一个例子来展示。

父组件:

<template>    <div class="father">        <h4>这里是父组件</h4>        <child>            <div class="tmpl">              <span>菜单1</span>              <span>菜单2</span>              <span>菜单3</span>              <span>菜单4</span>              <span>菜单5</span>              <span>菜单6</span>            </div>        </child>    </div></template>

子组件:

<template>    <div class="child">        <h4>这里是子组件</h4>        <slot></slot>    </div></template>

在这个例子里,因为父组件在<child></child>里面写了 html 模板,那么子组件的匿名插槽这块模板就是下面这样。也就是说,子组件的匿名插槽被使用了,是被下面这块模板使用了。

<div class="tmpl">  <span>菜单1</span>  <span>菜单2</span>  <span>菜单3</span>  <span>菜单4</span>  <span>菜单5</span>  <span>菜单6</span></div>

注:所有 demo 都加了样式,以方便观察。其中,父组件以灰色背景填充,子组件都以浅蓝色填充。

具名插槽

匿名插槽没有 name 属性,所以是匿名插槽,那么,插槽加了 name 属性,就变成了具名插槽。具名插槽可以在一个组件中出现N次。出现在不同的位置。下面的例子,就是一个有两个具名插槽和单个插槽的组件,这三个插槽被父组件用同一套 CSS 样式显示了出来,不同的是内容上略有区别。

父组件:

<template>  <div class="father">    <h4>这里是父组件</h4>    <child>      <div class="tmpl" slot="up">        <span>菜单1</span>        <span>菜单2</span>        <span>菜单3</span>        <span>菜单4</span>        <span>菜单5</span>        <span>菜单6</span>      </div>      <div class="tmpl" slot="down">        <span>菜单-1</span>        <span>菜单-2</span>        <span>菜单-3</span>        <span>菜单-4</span>        <span>菜单-5</span>        <span>菜单-6</span>      </div>      <div class="tmpl">        <span>菜单->1</span>        <span>菜单->2</span>        <span>菜单->3</span>        <span>菜单->4</span>        <span>菜单->5</span>        <span>菜单->6</span>      </div>    </child>  </div></template>

子组件:

<template>  <div class="child">    // 具名插槽    <slot name="up"></slot>    <h4>这里是子组件</h4>    // 具名插槽    <slot name="down"></slot>    // 匿名插槽    <slot></slot>  </div></template>

可以看到,父组件通过 html 模板上的 slot 属性关联具名插槽。没有 slot 属性的 html 模板默认关联匿名插槽。

作用域插槽 | 带数据的插槽

最后,就是我们的作用域插槽。这个稍微难理解一点。官方叫它作用域插槽,实际上,对比前面两种插槽,我们可以叫它带数据的插槽。什么意思呢,就是前面两种,都是在组件的 template 里面写

匿名插槽<slot></slot>具名插槽<slot name="up"></slot>

但是作用域插槽要求,在 slot 上面绑定数据。也就是你得写成大概下面这个样子。

<slot name="up" :data="data"></slot> export default {    data: function(){      return {        data: ['zhangsan','lisi','wanwu','zhaoliu','tianqi','xiaoba']      }    },}

我们前面说了,插槽最后显示不显示是看父组件有没有在 child 下面写模板,像下面那样。

<child>   html模板</child>

写了,插槽就总得在浏览器上显示点东西,东西就是 html 该有的模样,没写,插槽就是空壳子,啥都没有。OK,我们说有html模板的情况,就是父组件会往子组件插模板的情况,那到底插一套什么样的样式呢,这由父组件的 html+css 共同决定,但是这套样式里面的内容呢?

正因为作用域插槽绑定了一套数据,父组件可以拿来用。于是,情况就变成了这样:样式父组件说了算,但内容可以显示子组件插槽绑定的。

我们再来对比,作用域插槽和单个插槽和具名插槽的区别,因为单个插槽和具名插槽不绑定数据,所以父组件是提供的模板要既包括样式由包括内容的,上面的例子中,你看到的文字,“菜单1”,“菜单2”都是父组件自己提供的内容;而作用域插槽,父组件只需要提供一套样式(在确实用作用域插槽绑定的数据的前提下)。

下面的例子,你就能看到,父组件提供了三种样式(分别是 flex、ul、直接显示),都没有提供数据,数据使用的都是子组件插槽自己绑定的那个人名数组

父组件:

<template>  <div class="father">    <h4>这里是父组件</h4>    <!--第一次使用:用flex展示数据-->    <child>      <template slot-scope="user">        <div class="tmpl">          <span v-for="item in user.data">{{item}}</span>        </div>      </template>     </child>     <!--第二次使用:用列表展示数据-->    <child>      <template slot-scope="user">        <ul>          <li v-for="item in user.data">{{item}}</li>        </ul>      </template>     </child>     <!--第三次使用:直接显示数据-->    <child>      <template slot-scope="user">       {{user.data}}      </template>     </child>     <!--第四次使用:不使用其提供的数据, 作用域插槽退变成匿名插槽-->    <child>      我就是模板    </child>  </div></template>

子组件:

<template>  <div class="child">     <h4>这里是子组件</h4>    // 作用域插槽    <slot  :data="data"></slot>  </div></template>  export default {    data: function(){      return {        data: ['zhangsan','lisi','wanwu','zhaoliu','tianqi','xiaoba']      }    }}

到此,相信大家对“vue中的slot与slot-scope实例分析”有了更深的了解,不妨来实际操作一番吧!这里是编程网网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!

--结束END--

本文标题: vue中的slot与slot-scope实例分析

本文链接: https://lsjlt.com/news/309348.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • vue中的slot与slot-scope实例分析
    本篇内容主要讲解“vue中的slot与slot-scope实例分析”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“vue中的slot与slot-scope实例分析”吧!写在前面vue 中关于插槽的...
    99+
    2023-06-27
  • vue中slot与slot-scope的区别是什么
    vue中slot与slot-scope的区别是什么,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。单个插槽 | 默认插槽 | 匿...
    99+
    2024-04-02
  • vue中使用slot与slot-scope有什么区别
    本文小编为大家详细介绍“vue中使用slot与slot-scope有什么区别”,内容详细,步骤清晰,细节处理妥当,希望这篇“vue中使用slot与slot-scope有什么区别”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习...
    99+
    2023-07-04
  • vue template中slot-scope/scope怎么用
    这篇文章主要为大家展示了“vue template中slot-scope/scope怎么用”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“vue template...
    99+
    2024-04-02
  • 深入理解vue中的 slot-scope=“scope“
    目录理解vue的 slot-scope=“scope“vue中的slot和slot-scope使用插槽的作用具名插槽 作用域插槽总结理解vue的 s...
    99+
    2022-12-09
    vue slot-scope=scope slot-scope=scope
  • vue的slot-scope/scope属性如何用
    这篇文章主要介绍了vue的slot-scope/scope属性如何用的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇vue的slot-scope/scope属性如何用文章都会有所收获,下面我们一起来看看吧。在vu...
    99+
    2023-07-04
  • vue中的slot-scope及scope.row用法
    目录slot-scope及scope.row的用法vue项目中slot-scope="scope"报错scope is defined but never use...
    99+
    2024-04-02
  • slot-scope怎么在Vue中使用
    slot-scope怎么在Vue中使用?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。<!DOCTYPE html><html lang=&...
    99+
    2023-06-14
  • vue中slot内容分发的示例分析
    小编给大家分享一下vue中slot内容分发的示例分析,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!vue的内容分发非常适合“固定...
    99+
    2024-04-02
  • vue中slot分发内容的示例分析
    这篇文章主要为大家展示了“vue中slot分发内容的示例分析”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“vue中slot分发内容的示例分析”这篇文章吧。slot分发内容 (多个分发) ...
    99+
    2023-06-29
  • slot使用实例分析
    这篇文章主要介绍“slot使用实例分析”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“slot使用实例分析”文章能帮助大家解决问题。   使用slot场景一:  ...
    99+
    2024-04-02
  • Vue中内容分发<slot>​的示例分析
    这篇文章主要介绍Vue中内容分发<slot>的示例分析,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!首先 Vue 实现了一套内容分发的 API,这套 API 是基于当前的...
    99+
    2024-04-02
  • Vue中slot-scope的深入理解(适合初学者)
    百度上已经有很多的关于slot-scope的文章,但我感觉都是那些以前没学好,又回头学的人,他们都使用了.Vue文件,我觉得有点不适合初学者,所以我就写一篇适合初学者的。 先抛例程:...
    99+
    2024-04-02
  • Vue.js之slot深度复制的示例分析
    这篇文章给大家分享的是有关Vue.js之slot深度复制的示例分析的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。前言在Vue中,slot是一个很有用的特性,可以用来向组件内部插入...
    99+
    2024-04-02
  • Vue中slot的使用详解
    目录使用 slot基础用法具名插槽作用域插槽slot 实现总结在Vue中,我们使用组件来组织页面和组织代码,类似于搭积木,每一个组件都是一个积木,使用一些相同或者不同组件就能搭建出我...
    99+
    2024-04-02
  • Vue中的slot如何使用
    这篇文章主要介绍了Vue中的slot如何使用的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇Vue中的slot如何使用文章都会有所收获,下面我们一起来看看吧。在Vue中,我们使用组件来组织页面和组织代码,类似于搭...
    99+
    2023-06-30
  • Vue中怎么使用slot实现内容分发
    这篇文章给大家介绍Vue中怎么使用slot实现内容分发,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。编译作用域在深入内容分发 API 之前,先明确内容在哪个作用域里编译。假定模板为&l...
    99+
    2024-04-02
  • vue中怎么使用slot分发内容
    这篇文章将为大家详细讲解有关vue中怎么使用slot分发内容,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。一、什么是slot在使用组件时,我们常常要像这样组...
    99+
    2024-04-02
  • Vue中slot插槽作用与原理详解
    目录1、作用2、插槽内心2.1、默认插槽2.2、具名插槽(命名插槽)2.3、作用域插槽实现原理1、作用 父组件向子组件传递内容扩展、复用、定制组件 2、插槽内心 2.1、默认插槽 把...
    99+
    2024-04-02
  • Vue中插槽slot的使用方法与应用场景详析
    什么是插槽? 我们知道在Vue中 Child 组件的标签 的中间是不可以包着什么的 。 可是往往在很多时候我们在使用组件的时候总想在组件间外面自定义一些标签,vue新增了一种插槽...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作