slot分发内容步骤详解

这次给大家带来slot分发内容步骤详解,slot分发内容的注意事项有哪些,下面就是实战案例,一起来看一下。

一、什么是slot

在使用组件时,我们常常要像这样组合它们:

  

登录后复制

当需要让组件组合使用,混合父组件的内容与子组件的模板时,就会用到slot , 这个过程叫作内容分发( transclusion )。

注意两点:

1.

2. 组件很可能有它自己的模板。

props 传递数据、events 触发事件和slot 内容分发就构成了Vue 组件的3 个API 来源,再复杂的组件也是由这3 部分构成的。

 二、作用域

 {{ message }}

登录后复制

这里的message 就是一个slot ,但是它绑定的是父组件的数据,而不是组件<child-component>的数据。

父组件模板的内容是在父组件作用域内编译,子组件模板的内容是在子组件作用域内编译。如:

   

Vue.component('child-component',{ template: '

子组件

'});var app15 = new Vue({ el: '#app15', data: { showChild: true }});

登录后复制

这里的状态showChild 绑定的是父组件的数据,如果想在子组件上绑定,那应该是:

    

Vue.component('child-component',{ template: '

子组件

', data: function(){ return { showChild: true } }});

登录后复制

因此, slot 分发的内容,作用域是在父组件上的。

三、slot用法

3.1 单个slot

在子组件内使用特殊的<slot>元素就可以为这个子组件开启一个slot(插槽),在父组件模板里,插入在子组件标签内的所有内容将替代子组件的 标签及它的内容。   

 

分发的内容

更多分发的内容

Vue.component('my-component16',{ template: '

' + '

如果父组件没有插入内容,我将作为默认出现<

' +    //预留的slot插槽 '

'});var app16 = new Vue({ el: '#app16'});

登录后复制

渲染结果为:

分发的内容

更多分发的内容

登录后复制

 子组件child-component 的模板内定义了一个<slot>元素,并且用一个<p>作为默认的内容,在父组件没有使用slot 时,会渲染这段默认的文本;如果写入了slot, 那就会替换整个<slot> 。

3.2具名slot

给<slot> 元素指定一个name 后可以分发多个内容,具名Slot 可以与单个slot 共存。

  

标题

正文内容

更多正文内容

底部信息

Vue.component('my-component17',{ template: '

' + '

' + '' + '

' + '

' + '' + '

'+ ''+ '

'});var app17 = new Vue({ el: '#app17'});

登录后复制

渲染结果为:         

 

标题

正文内容

更多正文内容

底部信息

登录后复制

 子组件内声明了3 个<s lot>元素,其中在<p class=” main >内的<slot> 没有使用name 特性,它将作为默认slot 出现,父组件没有使用slot 特性的元素与内容都将出现在这里。

如果没有指定默认的匿名slot ,父组件内多余的内容片段都将被抛弃。

四、作用域插槽

作用域插槽是一种特殊的slot ,使用一个可以复用的模板替换己渲染元素。

看一个例子:     

 

来自父组件的内容

{{props.msg}}

Vue.component('my-component18',{ template: '

'});var app18 = new Vue({ el: '#app18'});

登录后复制

观察子组件的模板,在元素上有一个类似props 传递数据给组件的写法msg=” xxx ”,将数据传到了插槽。

父组件中使用了<template>元素,而且拥有一个scope=”props ”的特性,这里的props只是一个临时变量,就像v-for= ” item in items 里面的item 一样,template 内可以通过临时变量props访问来自子组件插槽的数据msg 。

下面看下Vue组件中slot的用法

主要是让组件的可扩展性更强。

1. 使用匿名slot

slot分发内容步骤详解

2. 给slot加个名字

slot分发内容步骤详解

如果不在有slot的组件里加入任何标签,slot什么都不会显示的。

相信看了本文案例你已经掌握了方法,更多精彩请关注【创想鸟】其它相关文章!

推荐阅读:

webpack自动刷新使用详解

Angular入口组件与声明式组件使用详解

以上就是slot分发内容步骤详解的详细内容,更多请关注【创想鸟】其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/2765987.html

(0)
上一篇 2025年3月8日 11:06:34
下一篇 2025年3月6日 11:32:51

AD推荐 黄金广告位招租... 更多推荐

相关推荐

  • props传递数据步骤详解

    这次给大家带来props传递数据步骤详解 ,props传递数据的注意事项有哪些,下面就是实战案例,一起来看一下。 在 Vue 中,父子组件的关系可以总结为 props向下传递,事件向上传递。父组件通过 props 给子组件下发数据,子组件通…

    2025年3月8日
    200
  • animate过渡动画使用详解

    这次给大家带来animate过渡动画使用详解,animate过渡动画使用的注意事项有哪些,下面就是实战案例,一起来看一下。 简介: transition方法的使用 transition内置方法 transition-group  anima…

    编程技术 2025年3月8日
    200
  • vue组件与复用使用详解

    这次给大家带来vue组件与复用使用详解,vue组件与复用使用的注意事项有哪些,下面就是实战案例,一起来看一下。 一、什么是组件 组件 (Component) 是 Vue.js 最强大的功能之一。组件可以扩展 HTML 元素,封装可重用的代码…

    编程技术 2025年3月8日
    200
  • vue-i18n标准的使用步骤

    这次给大家带来vue-i18n标准的使用步骤,vue-i18n标准使用的注意事项有哪些,下面就是实战案例,一起来看一下。 需求 公司项目需要国际化,点击按钮切换中文/英文 1、安装 npm install vue-i18n –save 登…

    编程技术 2025年3月8日
    200
  • Vue无限加载vue-infinite-loading使用详解

    这次给大家带来Vue无限加载vue-infinite-loading使用详解,Vue无限加载vue-infinite-loading使用的注意事项有哪些,下面就是实战案例,一起来看一下。 本文介绍了Vue中的无限加载vue-infinite…

    编程技术 2025年3月8日
    200
  • React Router v4使用详解

    这次给大家带来React Router v4使用详解,React Router v4使用的注意事项有哪些,下面就是实战案例,一起来看一下。 江湖传言,目前官方同时维护 2.x 和 4.x 两个版本。(ヾ(。ꏿ﹏ꏿ)ノ゙咦,此刻相信机智如我的…

    2025年3月8日
    200
  • Angular 5.x中Router使用详解

    这次给大家带来Angular 5.x中Router使用详解,Angular 5.x中Router使用的注意事项有哪些,下面就是实战案例,一起来看一下。 序言: Angular APP 视图之间的跳转,依赖于 Router (路由),这一章,…

    2025年3月8日
    200
  • js确认框confirm()用法实例详解

    这篇文章主要针对js确认框confirm()用法进行实例讲解,介绍了javascript确认框的三种使用方法,感兴趣的小伙伴们可以参考一下 先为大家介绍javascript确认框的三种使用方法,具体内容如下 第一种方法:挺好用的,确认以后才…

    2025年3月8日
    200
  • Vue做出内部组件轮播切换步骤详解

    这次给大家带来Vue做出内部组件轮播切换步骤详解,Vue做出内部组件轮播切换的注意事项有哪些,下面就是实战案例,一起来看一下。 对于那些不需要路由的内部组件,在切换的时候希望增加一个轮播过渡的效果,效果如下: 我们可以引入一个轮播组件,但是…

    2025年3月8日 编程技术
    200
  • Vue使用Sortable步骤详解

    这次给大家带来Vue使用Sortable步骤详解,Vue使用Sortable的注意事项有哪些,下面就是实战案例,一起来看一下。 之前开发一个后台管理系统,里面用到了Vue和Element-UI这个组件库,遇到一个挺有意思的问题,和大家分享一…

    编程技术 2025年3月8日
    200

发表回复

登录后才能评论