百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术分类 > 正文

vue2中动态组件、命令式组件和插槽有啥区别?

ztj100 2025-03-14 22:33 26 浏览 0 评论

准备工作

我的 vue 版本为:

 "vue": "^2.5.2"

动态组件

概念

动态组件顾名思义可以动态切换组件,允许我们根据不同的条件渲染不同的组件,通过 Vue 的 元素和特殊的 is attribute 实现

 

其中 is 的取值可以是:

  • 被注册的组件名
  • 导入的组件对象

当使用 来在多个组件间作切换时,被切换掉的组件会被卸载 实践 脚手架新建一个 vue2 项目后,我们新建一个 DynamicCom 组件,然后修改 router 配置

添加图片注释,不超过 140 字(可选)

页面重新渲染

添加图片注释,不超过 140 字(可选)

新建 3 个子组件

添加图片注释,不超过 140 字(可选)

修改DynamicCom.vue文件代码,实现动态组件


<script>
import NineOne from '../components/NineOne.vue'
import NineTwo from '../components/NineTwo.vue'
import NineThree from '../components/NineThree.vue'
export default {
    components: {
        NineOne,
        NineTwo,
        NineThree
    },
    data() {
        return {
            // tabs内元素为按需渲染的组件名
            tabs: ['NineOne', 'NineTwo', 'NineThree'],
            currentTab: 'NineOne', // 当前活跃组件名
            currActiveBtn: 'NineOne'
        }
    },
    methods: {
        handleSwitchCom(tab) {
            this.currentTab = tab; // 切换组件
            this.currActiveBtn = tab;
        }
    }
}
</script>

当我们切换按钮时,可以看到对应的组件也被渲染,其中关键代码就是component标签的应用,以上即是一个简单的动态组件

添加图片注释,不超过 140 字(可选)

命令式组件 概念 对于我们所熟知的弹窗组件而言,基本实现思路是父组件向子组件传参,点击关闭/确定按钮时通过 emit 回传事件供父组件调用,这种方式代码复用性差、使用频繁时需要定义多份 isVisiblehandleSubmit 代码,造成代码冗余 所以,命令式组件被发明了,我们将功能封装在组件内部,并通过命令式的方式去调用。组件负责封装一定的功能逻辑,提供一组接口或方法。 我们经常使用的 this.$Message 就是一个典型的例子,类似于调用函数的 api ,就能轻松实现组件的渲染

 this.$Message({
     message: 'thie is a message',
     type: 'warn'
 });

实践

我们在 comopnents 目录下新建 message 文件夹用于编写自定义 message 组件,然后在 views 中新增 CommandCom.vue 文件用于使用 message 组件

代码结构如下

添加图片注释,不超过 140 字(可选)

CommandCom.vue 代码如下


<script>
import $message from '../components/message';
export default {
    methods: {
        open() {
            /* 1、引入组件的方式使用 2、直接通过this调用 */
            $message();
            // 想要直接通过this调用该方法,需要保存Vue实例,注册install方法,将该函数挂载到Vue根实例原型,再全局引入
            this._Message();
        },
    },
};
</script>

message 组件的 js 代码

import Main from './main.vue';
import Vue from 'vue'
function message(
    message = '我是一条消息!',
    title = '标题',
    options = {
        confirmButtonText: '确定',
        cancelButtonText: '取消',
        type: 'info',
    }
) {
  return new Promise((resolve, reject) => {
      // 使用extend将组件转为构造函数
      const MessageBox = Vue.extend(Main); // 生成一个新的带有默认参数的Vue的子类
      // 实例化MessageBox组件
      const messageBox = new MessageBox({
          data() {
              return {
                message,
                title,
                options,
                messageBoxVisible: true,
              };
          },
          methods: {
              resolve,
              reject,
          },
      });
      // 调用$mount()不传递参数 触发模板编译流程
      messageBox.$mount(); // 用于手动挂载,触发Vue的编译流程
      // 通过messageBox实例的$el属性获取到真实DOM,挂载到页面
      document.body.appendChild(messageBox.$el);
  });
}
message.install = function () {
    //挂载到原型
    Vue.prototype._Message = this;
};
export default message;

message 组件的 vue 代码


<script>
export default {
    methods: {
        hide() {
            this.messageBoxVisible = false;
            this.$nextTick(() => this.$destroy());
        },
        cancel() {
            this.reject();
            this.hide();
        },
        confirm() {
            this.resolve();
            this.hide();
        },
    },
};
</script>

点击按钮后,下方出现提示内容,点击「确定」或「取消」能够关闭提示 此时内容非常简洁,没有任何样式,如果是完整的 message,我们还需要实现 message 淡入淡出的效果,以及 message 上标题、内容和按钮的样式(本篇只关注功能,对于样式不做过多说明)

添加图片注释,不超过 140 字(可选)

值得注意的是,如果我们想要直接使用 this 调用组件,需要在 router 中添加 2 行代码

添加图片注释,不超过 140 字(可选)

我们的 message 是一个函数,为了使用 Vue.use(),我们需要为其注册一个install方法,将自定义的 message 实例挂载到 Vue 原型上

添加图片注释,不超过 140 字(可选)

message.install = function () {
    //挂载到原型
    Vue.prototype._Message = this;
};

总结:命令式组件的基本实现原理在于利用Vue.extend方法创建一个具备默认参数的Vue子类, 将自定义组件转为构造函数,然后实例化组件,传入我们的数据配置对象,再调用$mount()方法手动挂载组件,进而触发 Vue 的编译流程 同时,为了直接使用 this 调用组件,我们定义了组件的 install 方法,将 message 函数挂载到了 Vue 的原型上 插槽 概念 vue2 中,我们可以使用 元素创建一个插槽,这允许我们的组件接收任意内容 实践 新建父组件 SlotCom.vue 文件


<script>
import NineFour from './NineFour.vue';
export default {
    components: {
        NineFour,
    },
};
</script>

新建子组件 NineFour.vue 文件


<script>
export default {
};
</script>

效果如图,在使用子组件的同时,我们可以额外添加元素渲染

添加图片注释,不超过 140 字(可选)

更加深入的用法可以参考官网文档

【腾讯文档】资料获取方式!!

资料获取方式!!

异同 相同点

  1. 用于组件交互和渲染
  2. 代码更加灵活

不同点:

  1. 插槽(Slot)

  • 插槽是一种内容分发机制,允许父组件向子组件传递内容并渲染
  • 插槽是声明式的方式,通过在组件模板中使用 标签来定义插槽的位置和默认内容
  • 插槽是静态的,父组件在渲染子组件时可以在模板中传递内容到插槽
  1. 命令式组件

  • 命令式组件通过调用组件的构造函数或工厂函数来创建组件实例,并手动挂载到指定的 DOM 元素上
  1. 动态组件

  • 动态组件允许我们在父组件中动态地切换不同子组件
  • 动态组件通过在父组件的模板中使用 标签,并绑定动态的组件名
  • 动态组件允许根据某些条件动态地切换子组件

应用场景:

  • 插槽(Slot) :适用于需要将父组件的内容传递给子组件并在特定位置展示的场景,例如在布局组件中传递不同的内容到插槽中
  • 命令式组件:适用于需要在特定条件下动态创建并显示组件的场景,例如在弹出框、提示框或下拉框等需要手动触发显示的情况
  • 动态组件:适用于需要根据条件或事件动态切换显示不同子组件的场景,例如在标签页切换、路由导航等需要动态加载不同组件的情况

写在最后 插槽、命令式组件和动态组件是 Vue 中常用的组件交互和渲染方式,它们各有千秋,在不同的场景下有着各自的应用, 我们可以根据具体需求选择合适的方式实现组件的交互和显示

相关推荐

30天学会Python编程:16. Python常用标准库使用教程

16.1collections模块16.1.1高级数据结构16.1.2示例...

强烈推荐!Python 这个宝藏库 re 正则匹配

Python的re模块(RegularExpression正则表达式)提供各种正则表达式的匹配操作。...

Python爬虫中正则表达式的用法,只讲如何应用,不讲原理

Python爬虫:正则的用法(非原理)。大家好,这节课给大家讲正则的实际用法,不讲原理,通俗易懂的讲如何用正则抓取内容。·导入re库,这里是需要从html这段字符串中提取出中间的那几个文字。实例一个对...

Python数据分析实战-正则提取文本的URL网址和邮箱(源码和效果)

实现功能:Python数据分析实战-利用正则表达式提取文本中的URL网址和邮箱...

python爬虫教程之爬取当当网 Top 500 本五星好评书籍

我们使用requests和re来写一个爬虫作为一个爱看书的你(说的跟真的似的)怎么能发现好书呢?所以我们爬取当当网的前500本好五星评书籍怎么样?ok接下来就是学习python的正确姿...

深入理解re模块:Python中的正则表达式神器解析

在Python中,"re"是一个强大的模块,用于处理正则表达式(regularexpressions)。正则表达式是一种强大的文本模式匹配工具,用于在字符串中查找、替换或提取特定模式...

如何使用正则表达式和 Python 匹配不以模式开头的字符串

需要在Python中使用正则表达式来匹配不以给定模式开头的字符串吗?如果是这样,你可以使用下面的语法来查找所有的字符串,除了那些不以https开始的字符串。r"^(?!https).*&...

先Mark后用!8分钟读懂 Python 性能优化

从本文总结了Python开发时,遇到的性能优化问题的定位和解决。概述:性能优化的原则——优化需要优化的部分。性能优化的一般步骤:首先,让你的程序跑起来结果一切正常。然后,运行这个结果正常的代码,看看它...

Python“三步”即可爬取,毋庸置疑

声明:本实例仅供学习,切忌遵守robots协议,请不要使用多线程等方式频繁访问网站。#第一步导入模块importreimportrequests#第二步获取你想爬取的网页地址,发送请求,获取网页内...

简单学Python——re库(正则表达式)2(split、findall、和sub)

1、split():分割字符串,返回列表语法:re.split('分隔符','目标字符串')例如:importrere.split(',','...

Lavazza拉瓦萨再度牵手上海大师赛

阅读此文前,麻烦您点击一下“关注”,方便您进行讨论和分享。Lavazza拉瓦萨再度牵手上海大师赛标题:2024上海大师赛:网球与咖啡的浪漫邂逅在2024年的上海劳力士大师赛上,拉瓦萨咖啡再次成为官...

ArkUI-X构建Android平台AAR及使用

本教程主要讲述如何利用ArkUI-XSDK完成AndroidAAR开发,实现基于ArkTS的声明式开发范式在android平台显示。包括:1.跨平台Library工程开发介绍...

Deepseek写歌详细教程(怎样用deepseek写歌功能)

以下为结合DeepSeek及相关工具实现AI写歌的详细教程,涵盖作词、作曲、演唱全流程:一、核心流程三步法1.AI生成歌词-打开DeepSeek(网页/APP/API),使用结构化提示词生成歌词:...

“AI说唱解说影视”走红,“零基础入行”靠谱吗?本报记者实测

“手里翻找冻鱼,精心的布局;老漠却不言语,脸上带笑意……”《狂飙》剧情被写成歌词,再配上“科目三”背景音乐的演唱,这段1分钟30秒的视频受到了无数网友的点赞。最近一段时间随着AI技术的发展,说唱解说影...

AI音乐制作神器揭秘!3款工具让你秒变高手

在音乐创作的领域里,每个人都有一颗想要成为大师的心。但是面对复杂的乐理知识和繁复的制作过程,许多人的热情被一点点消磨。...

取消回复欢迎 发表评论: