博客
关于我
封装vue的弹窗组件
阅读量:328 次
发布时间:2019-03-04

本文共 1462 字,大约阅读时间需要 4 分钟。

工具函数创建组件实例

工具函数说明

为了实现组件实例的创建与管理,我们编写了一个工具函数 create,该函数负责根据传入的组件类和属性参数,创建一个新的 Vue 实例,并将其挂载至页面中。

工具函数实现步骤

  • 创建 Vue 实例:使用 Vue 框架创建一个新的实例,并配置其渲染逻辑
  • 渲染组件:通过 render 函数,将传入的组件进行渲染
  • 挂载实例:将创建好的 Vue 实例挂载到 HTML 页面的 body 标签上
  • 获取组件实例:通过 Vue 实例获取创建的组件实例
  • 生命周期管理:定义组件的生命周期回调函数,确保组件的创建和销毁能够被正确管理
  • // 创建指定组件实例并挂载于body上import Vue from 'vue';export default function create(Component, props) {    const vm = new Vue({        render(h) {            return h(Component, {                props            });        }    }).$mount();    const comp = vm.$children[0];    document.body.appendChild(vm.$el);    // 定义清理函数    comp.remove = () => {        document.body.removeChild(vm.$el);        vm.$destroy();    };    return comp;}

    Notice 组件

    组件代码

    组件说明

  • 模板部分:使用 v-if 指令控制组件的显示与隐藏
  • 属性定义:组件接受三个属性 titlemessageduration
  • 生命周期方法
    • show():用于显示组件,并设置自动关闭的时间
    • hide():用于隐藏组件并移除实例
  • 双向数据绑定:通过 data()methods 属性管理组件的状态和交互逻辑
  • 组件使用场景

    示例应用

    在登录功能中,通常需要在用户输入验证通过后,显示一个通知窗口。可以通过以下方式实现:

    methods: {    onLogin() {        return this.$refs.loginForm.validate((isValid) => {            if (!isValid) return;            const notice = create(Notice, {                title: "欢迎登录",                message: "请根据提示进行登录",                duration: 3000            });            notice.show();        });    }}

    使用说明

  • 组件引用:在需要显示通知的位置,引用 Notice 组件
  • 属性传递:通过 props 属性将组件的属性进行传递
  • 生命周期管理:通过 create 工具函数确保组件的生命周期被正确管理
  • 自动关闭:通过 duration 属性设置自动关闭时间,确保页面不会被长时间占用
  • 转载地址:http://tvsh.baihongyu.com/

    你可能感兴趣的文章
    NIFI大数据进阶_离线同步MySql数据到HDFS_02_实际操作_splitjson处理器_puthdfs处理器_querydatabasetable处理器---大数据之Nifi工作笔记0030
    查看>>
    NIFI大数据进阶_连接与关系_设置数据流负载均衡_设置背压_设置展现弯曲_介绍以及实际操作---大数据之Nifi工作笔记0027
    查看>>
    NIFI数据库同步_多表_特定表同时同步_实际操作_MySqlToMysql_可推广到其他数据库_Postgresql_Hbase_SqlServer等----大数据之Nifi工作笔记0053
    查看>>
    NIFI汉化_替换logo_二次开发_Idea编译NIFI最新源码_详细过程记录_全解析_Maven编译NIFI避坑指南001---大数据之Nifi工作笔记0068
    查看>>
    NIFI集群_内存溢出_CPU占用100%修复_GC overhead limit exceeded_NIFI: out of memory error ---大数据之Nifi工作笔记0017
    查看>>
    NIFI集群_队列Queue中数据无法清空_清除队列数据报错_无法删除queue_解决_集群中机器交替重启删除---大数据之Nifi工作笔记0061
    查看>>
    NIH发布包含10600张CT图像数据库 为AI算法测试铺路
    查看>>
    Nim教程【十二】
    查看>>
    Nim游戏
    查看>>
    NIO ByteBuffer实现原理
    查看>>
    Nio ByteBuffer组件读写指针切换原理与常用方法
    查看>>
    NIO Selector实现原理
    查看>>
    nio 中channel和buffer的基本使用
    查看>>
    NIO三大组件基础知识
    查看>>
    NIO与零拷贝和AIO
    查看>>
    NIO同步网络编程
    查看>>
    NIO基于UDP协议的网络编程
    查看>>
    NIO笔记---上
    查看>>
    NIO蔚来 面试——IP地址你了解多少?
    查看>>
    NISP一级,NISP二级报考说明,零基础入门到精通,收藏这篇就够了
    查看>>