博客
关于我
封装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/

    你可能感兴趣的文章
    nsis 安装脚本示例(转)
    查看>>
    NSJSON的用法(oc系统自带的解析方法)
    查看>>
    nslookup 的基本知识与命令详解
    查看>>
    NSNumber与NSInteger的区别 -bei
    查看>>
    NSOperation基本操作
    查看>>
    NSRange 范围
    查看>>
    NSSet集合 无序的 不能重复的
    查看>>
    NSURLSession下载和断点续传
    查看>>
    NSUserdefault读书笔记
    查看>>
    NS图绘制工具推荐
    查看>>
    NT AUTHORITY\NETWORK SERVICE 权限问题
    查看>>
    NT symbols are incorrect, please fix symbols
    查看>>
    ntelliJ IDEA 报错:找不到包或者找不到符号
    查看>>
    NTFS文件权限管理实战
    查看>>
    ntko web firefox跨浏览器插件_深度比较:2019年6个最好的跨浏览器测试工具
    查看>>
    ntko文件存取错误_苹果推送 macOS 10.15.4:iCloud 云盘文件夹共享终于来了
    查看>>
    ntp server 用法小结
    查看>>
    ntpdate 通过外网同步时间
    查看>>
    ntpdate同步配置文件调整详解
    查看>>
    NTPD使用/etc/ntp.conf配置时钟同步详解
    查看>>