手把手教你玩转Vue.js组件(三)

简介: 上一节谈到有关Vue.js组件中“传参”的概念,我们使用的是Prop,也就是在标签上自定义属性来向子组件传递数据。这一节我们继续谈谈“传参”,只不过这次不是通过自定义属性,而是通过一个固定的自定义标签,它有个比较特别的名字:插槽。

上一节谈到有关Vue.js组件中“传参”的概念,我们使用的是Prop,也就是在标签上自定义属性来向子组件传递数据。这一节我们继续谈谈“传参”,只不过这次不是通过自定义属性,而是通过一个固定的自定义标签<slot>,它有个比较特别的名字:插槽

同样还是前面的例子,只不过有一点点小改动:

<!--HTML-->
<pop-tips ref="tips" src="./imgs/success.png"></pop-tips>
//pop-tips组件
Vue.component('pop-tips',{
    props: {
        duration: {
            type: Number,
            default: 2,
            validator: function (value) {
                return value <= 3;
            }
        },
        src: ''
    },
    data: function(){
        return {
            popShow: false,
            popText: ''
        }
    },
    template: '<div class="pop-tips" :class="{show: popShow}"><span><img v-if="src" :src="src" alt=""/>{{popText}}</span></div>',
    methods: {
        popTips: function(text){
            var _this = this;
            this.popShow = true;
            this.popText = text;
            setTimeout(function () {
                _this.popShow = false;
            },this.duration*1000);
        }
    }
});
// 实例调用组件方法
var vm = new Vue({
    el: '#app',
    methods: {
        showTips: function(){
            popTips('支付成功');
        }
    }
});
function popTips(text){
    vm.$refs.tips.popTips(text);
}

我在提示文字前添加了一张图片,这张图片路径通过Prop传递给子组件,效果如下图:


这效果就是典型的微信弹出提示。当然,若不传src属性,效果就只是纯文字提示:

<!--HTML-->
<pop-tips ref="tips"></pop-tips>

这就是组件灵活性的好处。那么,插槽到底是个什么东西呢?我们该如何使用它呢?

别着急,前面只是铺垫,接下来请听我娓娓道来~

同样是以上效果,我们也可以使用插槽来实现它:

<!--HTML-->
<pop-tips ref="tips">
    <!--替代组件中的slot元素-->
    <img src="./imgs/success.png" alt=""/>
</pop-tips>
//pop-tips组件
Vue.component('pop-tips',{
    //……
    template: '<div class="pop-tips" :class="{show: popShow}"><span><slot></slot>{{popText}}</span></div>',
    //……
});

最终页面上的渲染出来的HTML内容如下:

<div class="pop-tips"><span><img src="./imgs/success.png" alt="">支付成功</span></div>

也就是说组件模板中的<slot>标签是用于指定从父组件传入内容的替换位置,示例中就是将<slot>标签替换成<img>标签。当然,使用插槽有一个好处就是我们可以更加灵活地自定义组件,我们可以传入其他标签,也可以不传任何内容。

同样的,我们也可以给插槽设置默认值:

//pop-tips组件
Vue.component('pop-tips',{
    //……
    template: '<div class="pop-tips" :class="{show: popShow}"><span><slot><img src="./imgs/success.png" alt=""/></slot>{{popText}}</span></div>',
    //……
});

也就是将默认值放在<slot>标签中,但是这样做的话,无论你有没有传图片,最终渲染结果都会带有这张默认图片的。

说了这么多,在实际运用当中,什么时候我们应该使用Prop来“传参”,而什么时候我们又应该用<slot>元素呢?

以下是我个人简单的总结:

Prop:用于传递简单数据,适合需要自定义内容比较少的情况
<slot>: 用于传递标签内容,适合需要自定义内容比较复杂的情况,相对Prop来说更加灵活

所以说,以上所举的例子如果仅仅是为了能够自定义图片的话,完全可以只使用Prop来实现。

本文重点总结:

① 父组件向子组件传递数据最常用方法是Prop<slot>
Prop传递的数据是标签属性值,组件内props属性接收数据;<slot>传递的数据是子标签元素,组件内<slot>元素接收数据并且被替换

相关文章
|
5天前
|
JavaScript API
vue 批量自动引入并注册组件或路由等等
【10月更文挑战第12天】 vue 批量自动引入并注册组件或路由等等
|
5天前
|
JavaScript 前端开发 API
vue3中常用插件的使用方法:按需引入自定义组件,自动导入依赖包,自动生成路由,自动生成模拟数据
vue3中常用插件的使用方法:按需引入自定义组件,自动导入依赖包,自动生成路由,自动生成模拟数据
92 0
|
6天前
|
JavaScript
vue 组件中的 data 为什么是一个函数 ?
【10月更文挑战第8天】 在 Vue 组件中,`data` 被定义为一个函数而非普通对象,以确保每个组件实例拥有独立的数据空间,避免数据混乱。这种方式还支持数据的响应式更新、组件的继承与扩展,并有助于避免潜在问题,提升应用的可靠性和性能。
13 2
|
6天前
|
JavaScript 前端开发 UED
Vue 组件设计:构建生动多彩的树形结构组件
本文介绍了如何使用 Vue 构建一个功能强大的树形结构组件。该组件支持递归渲染节点及其子节点,提供了自定义节点颜色、文本和布局的功能。通过独特的样式处理不同层级的节点,展示出丰富的视觉效果。组件还支持动态布局和缩放,确保灵活的界面展示和用户体验。文章提供了详细的代码实现,包括 HTML、JavaScript 和 SCSS,帮助开发者快速集成和定制自己的树形结构组件。
27 0
Vue 组件设计:构建生动多彩的树形结构组件
|
7天前
|
JavaScript 搜索推荐
Vue 插槽全攻略:重塑组件灵活性
【10月更文挑战第7天】 Vue 的插槽(Slots)是一个强大的特性,用于增强组件的灵活性和可扩展性。插槽允许父组件向子组件传递内容,实现组件的复用和个性化展示。主要包括默认插槽、具名插槽和作用域插槽三种类型,分别适用于不同场景。通过插槽,可以提高组件的复用性、实现灵活的布局,并促进团队协作。
16 1
|
8天前
|
JavaScript
vue 函数化组件
【10月更文挑战第1天】 Vue.js 的函数化组件通过设置 `functional: true`,使其无状态和无实例,从而减少渲染开销。通过 `render` 函数的 `context` 参数传递数据。示例中,`smart-item` 组件根据 `data.type` 动态选择并渲染 `ImgItem`、`VideoItem` 或 `TextItem` 组件。根实例 `app` 通过按钮切换不同类型的组件数据。函数化组件适用于程序化选择组件和操作传递数据的场景。
|
12天前
|
前端开发 JavaScript API
Vue3商品SKU多规格编辑组件
Vue3商品SKU多规格编辑组件
34 5
|
9天前
|
JavaScript 前端开发
VUE学习三:双向绑定指令(v-mode)、组件化开发(全局组件/局部组卷/组件通信)、组件化高级(slot插槽使用)
这篇文章是关于Vue.js框架中的v-model指令和组件化开发的详细教程,涵盖了从基础使用到高级功能的多个方面。
19 1
|
9天前
|
JavaScript 程序员 开发者
你真的完全了解vue组件的概念吗?
【10月更文挑战第7天】你真的完全了解vue组件的概念吗?
|
11天前
|
缓存 JavaScript UED
vue的动态组件 keep-alive
【10月更文挑战第6天】
27 3