当前位置:首页 > 技术分析 > 正文内容

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

ruisui882个月前 (02-27)技术分析12

准备工作

我的 vue 版本为:

 "vue": "^2.5.2"

动态组件

概念

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

 

其中 is 的取值可以是:

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

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

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

页面重新渲染

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

新建 3 个子组件

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

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


当我们切换按钮时,可以看到对应的组件也被渲染,其中关键代码就是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 代码如下


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 代码



点击按钮后,下方出现提示内容,点击「确定」或「取消」能够关闭提示 此时内容非常简洁,没有任何样式,如果是完整的 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 文件


新建子组件 NineFour.vue 文件


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

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

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

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

资料获取方式!!

异同 相同点

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

不同点:

  1. 插槽(Slot)

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

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

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

应用场景:

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

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

扫描二维码推送至手机访问。

版权声明:本文由ruisui88发布,如需转载请注明出处。

本文链接:http://www.ruisui88.com/post/2302.html

标签: vue弹窗组件
分享给朋友:

“vue2中动态组件、命令式组件和插槽有啥区别?” 的相关文章

「图解」父子组件通过 props 进行数据交互的方法

1.组件化开发,经常有这样的一个场景,就是父组件通过 Ajax 获取数据,传递给子组件,如何通过 props 进行数据交互来实现,便是本图解的重点。2.代码的结构3.具体代码 ①在父组件 data 中存放数据 ms。 ②将父组件 data 中的数据 ms 绑定到子组件中的属性 ms。 ③子组件在 p...

vue3父子组件传对象,子组件访问修改父组件对象中的属性值

在Vue 3中,父子组件之间的数据传输通常通过props和emit进行。父组件可以通过props向下传递数据给子组件,子组件则可以通过emit向上通知父组件更新数据。如果需要在子组件中修改父组件对象中的属性值,可以使用一个名为ref的Vue 3新特性。以下是一个示例,演示了如何在Vue 3中实现父子...

GitLab-创建分支

描述分支是独立的生产线,是开发过程的一部分。分支的创建涉及以下步骤。创建一个分支步骤1-登录您的GitLab帐户,然后转到“ 项目”部分下的项目。步骤2-要创建分支,请单击“ 存储库”部分下的“ 分支”选项,然后单击“ 新建分支”按钮。步骤3-在“ 新建分支”屏幕中,输入分支的名称,然后单击“ 创建...

79.idea中git合并分支操作分享

文章目录前言1.fetch的操作2.合并最新代码到当前的开发分支3.解决冲突4.分支合并:5.完成代码合并总结前言git的操作在日产的工作中也非常重要,团队化的代码管理,每次如果代码被别人覆盖或者自己的代码不能提交到服务器那是灾难性的结果,本篇进行一篇分享来总结下idea中git的操作帮助java开...

10款超牛Vim插件,爱不释手了

我是一个忠实的Vim编辑器用户,从事开发工作多年,我一直都非常喜欢使用Vim。轻量、便捷,而且,熟悉了Vim相关的快捷键之后,效率能够成倍的提升。除了这些之外,Vim像很多知名的IDE、编辑器一样,也支持插件配置,通过这些插件,可以实现更多高级、高效的操作。今天,就来给大家分享10个我特别喜欢的Vi...

虚幻引擎5.5现已发布 手游开发、动画制作重大改进

Epic在今天发布了虚幻引擎5.5,现可通过Epic Launcher下载。此版本在动画创作、渲染、虚拟制片、移动端游戏开发和开发人员迭代工具集等方面做出了重大改进。 官方博客:虚幻引擎5.5现已发布,在动画创作、虚拟制作和移动游戏开发方面取得了显著进步,渲染、摄像机内视觉特效和开发人员迭代等领域的...