模态框是我们 UI 控件中一个很重要的组件,使用场景有很多种,我们在 Vue 组件中创建模态框组件而用到的一个知识点是利用 Vue.extend 来创建。文档中的解释是 

在最近在做一个常用的类似下面的登录/注册业务场景时,利用 Vue.extend 来改善我们的代码,使我们代码逻辑更清晰化。

需求:点击登录或注册出现各自的模态框。

我们对于这种常见的登录注册业务,一般都是分为 Sigin.vue 和 Register.vue 两个组件,然后把两个组件写入 App.vue 组件中,或者是 layout.vue 组件中。

原来的这种使用,对于我们的整块的登录注册逻辑是分散的,一些需要登录或者是权限的逻辑,可能都需要特意去提取一个 Visible 来控制我们的登录框。

使用 Vue.extend 可以达到统一接口,不用逻辑分散,下面的示例,仅作参考,不了解该 api 使用的可以了解下,而了解的,欢迎指导?

组件

新建 LoginModel 目录,新建 Sigin.vue 和 Register.vue 两个组件

登录
注册

复制代码

再新建 index.vue 组件

v-if="show">v-if="type === 'sigin'" @sigin="loginCallback" />v-if="type === 'register'" @register="loginCallback" />

import Sigin from "./sigin";
import Register from "./register";
export default {
components: {
Register,
Sigin
},
data() {
return {
show: false,
type: "sigin"
};
}
};

复制代码

创建子类

新建 index.js,导入我们的 index.vue

import Vue from "vue";import ModalCops from "./index.vue";

const LoginModal = Vue.extend(ModalCops); // 创建 Vue 子类

let instance;

const ModalBox = (options = {}) => {if (instance) {    instance.doClose();  }// 实例化  instance = new LoginModal({    data: {      show: true, // 实例化后显示      ...options    }  });  instance.$mount();document.body.appendChild(instance.$el); // 将模态框添加至 bodyreturn instance;};

// 对应的登录ModalBox.sigin = () => {return ModalBox({    type: "sigin"  });};

ModalBox.register = () => {return ModalBox({    type: "register"  });};

export default {install(Vue) {    Vue.prototype.$loginer = ModalBox;  }};

复制代码

创建完成后,我们可以在入口挂载到 Vue 实例上

// main.jsimport LoginModal from "./components/LoginModal";

Vue.use(LoginModal);复制代码

在需要登录/注册的地方只用调用

href="javascript:;" @click="onLogin('sigin')">登录
/href="javascript:;" @click="onLogin('register')">注册

onLogin(type) {
this.$loginer({
type
})
}
复制代码

效果如下

验证事件

我们都知道模态框需要关闭事件,而像这种业务的关闭事件必然是需要验证提交信息,所以我们需要加上关闭回调函数。
修改 Sigin.vue 和 Register.vue 两个组件,添加事件

// Sigin.vue
click="onClick">登录确认

export default {
name: "Sigin",
methods: {
onClick() {
this.$emit("sigin");
}
}
};

// Register.vue

click="onClick">注册确认

export default {
name: "Register",
methods: {
onClick() {
this.$emit("register");
}
}
};

复制代码

修改 index.vue 添加 $emit 事件

v-if="show">v-if="type === 'sigin'" @sigin="loginCallback" />v-if="type === 'register'" @register="loginCallback" />

import Sigin from "./sigin";
import Register from "./register";
export default {
components: {
Register,
Sigin
},
data() {
return {
show: false,
type: "sigin"
};
},
methods: {
loginCallback() {
if (!this.ok) return;
this.ok().then(valid => {
if (valid) {
this.doClose();
}
});
},
doClose() {
this.show = false;
}
}
};

复制代码

修改 index.js 文件

import Vue from "vue";import ModalCops from "./index.vue";

const LoginModal = Vue.extend(ModalCops);

let instance;

const ModalBox = (options = {}) => {if (instance) {    instance.doClose();  }  instance = new LoginModal({    data: {      show: true,      ...options    }  });  instance.ok = () => {return new Promise(resolve => {const before = options.ok ? options.ok() : false;if (before && before.then) {        before.then(          () => resolve(true),          () => {console.log("reject");          }        );      } else if (typeof before === "boolean" && before !== false) {        resolve(true);      }    });  };  instance.$mount();document.body.appendChild(instance.$el);return instance;};

ModalBox.sigin = ok => {return ModalBox({    type: "sigin",    ok  });};

ModalBox.register = ok => {return ModalBox({    type: "register",    ok  });};

ModalBox.close = () => {  instance.doClose();  instance.show = false;};

export default {install(Vue) {    Vue.prototype.$loginer = ModalBox;  }};

复制代码

使用回调

onLogin(type) {const funcs = {    sigin: () => {console.log("登录请求");    },    register: () => {console.log("注册请求");    }  };this.$loginer({    type,    ok: () => {return new Promise((resolve, reject) => {// isOk 验证数据是否正确if (this.isOk) {          funcs[type]();          resolve();        } else {          reject();        }      });    }  });}复制代码

效果如下

antd vue关闭模态对话框_Vue.extend 登录注册模态框相关推荐

  1. 来个模态kuang_模态对话框(modal dialogue box)中模态一词的意思是什么?

    这个问题也困扰了我很久.最近整理了下资料,写了一篇文章<5 分钟设计指南:对话框>,希望能帮上忙. 对话框 (dialogs) 是叠加在应用主视图上的弹出 (pop-up) 视图,一般会要 ...

  2. Win32_SDK_非模态对话框(非模态对话框窗口的销毁,模态与非模态对比,计算器项目练习)

    文章目录 1. 模态对话框与非模态对话框对比 2. 计算器项目练习模态与非模态对话框 3. 代码位置 1. 模态对话框与非模态对话框对比 模态对话框是通过DialogBox函数生成窗口,且函数的返回值 ...

  3. antd vue关闭模态对话框_如何在Bootstrap项目中用Vue.js替代jQuery

    Bootstrap是 Web 开发最受欢迎的框架之一,没有比它开发响应式网站项目效率最高了. 随着Vue.js的逐渐流行,更多人们用它来控制页面元素,实现强大互动功能.而jQuery出现了一些技术落后 ...

  4. vue.js确认对话框_vue.js精美的未保存的更改对话框

    vue.js确认对话框 Vue未保存的更改对话框 (Vue Unsaved Changes Dialog) A beautiful unsaved changes dialog, inspired b ...

  5. c#模态对话框从内部退出_C#模态对话框和非模态对话框

    模态对话框 弹出窗口阻止调用窗口的所有消息响应. 只有在弹出窗口结束后调用窗口才能继续. 在模态窗口"关闭"后,可以读取模态窗口中信息,包括窗口的返回状态,窗口子控件的值. 非模态 ...

  6. c#模态对话框从内部退出_c# – 如何在非模态对话框的顶部正确实现模态对话框?...

    在 WPF应用程序中,我想实现以下似乎不能直接起作用的行为: 从主窗口(Window1),用户打开非模态窗口(Window2),并且该非模态窗口可以显示模态对话框(Window3). 问题是,只要显示 ...

  7. antd vue关闭模态对话框_我不能没有的5个Vue.js库

    1.Click Off to Close 有的时候,我们需要在用户点击元素之外的时候触发一个事件.最常见的用例是当你想通过点击关闭一个下拉框或对话框时.这是一个必不可少的包,几乎在我构建的每个应用中都 ...

  8. vue展示信息卡片_vue实现登录和个人信息组件展示

    最近在写一个重构node社区的小项目,碰到了登录的问题,实现思路如下: 1.获取用户表单信息,使用axios提交,提交成功后,把数据存在cookie,以便后续操作. 2.其中有个人信息的页面展示,获取 ...

  9. antd vue form 手动校验_Vue 开发者不可错过的五款开源扩展组件

    自 2014 年正式对外发布以来,Vue 凭借着入门容易.资料丰富.框架功能完善等优势,成为国内许多前端开发者在众多 JavaScript 框架中的首选.Gitee 上这些优秀的开源 Vue 组件也侧 ...

最新文章

  1. Jackson 注解 -- 忽略字段
  2. zabbix—自动发现端口并监控
  3. php 合成图片 透明,2020-05-19 php实现透明png多图合成
  4. 2018蓝桥杯省赛---java---B---4(测试次数)
  5. C语言 gcc API
  6. ue4小白人骨骼定义_【Blender】用SkinModifier+骨骼顶点“灵活”快速创建雕刻需要用的基本人物模型...
  7. 利用更改Windows7粘滞键漏洞破解登录密码
  8. 【入门篇】黑盒测试基础
  9. 进阶 09 Map集合
  10. beanshell断言_jmeter之beanshell断言---数据处理
  11. 数字化图书馆软硬件环境要求-转自《博奥智源》
  12. 【随】BIDS 怪异现象
  13. linux下while循环,Bash 中的 while 循环详解
  14. 网页游戏对java的技术要求_网页制作谈谈什么技术是Java开发网页游戏的必要条件呢?怎样在微信公众平台上制作5级游戏?...
  15. apicloud——云编译失败
  16. 利用 Python 分析城市各区域楼盘
  17. 微信wifi路由器怎么连接服务器,介绍下微信WIFI路由器怎么设置的方法
  18. 华为在深度学习平台上的优化实践
  19. 天津外国语大学计算机专业,天津外国语大学bbs
  20. air flow空调上是什么意思_air flow空调滤芯上是什么意思

热门文章

  1. PAT乙级(1007 素数对猜想)
  2. 数据结构—链表-单链表基本操作实现
  3. jsp中java代码if_jsp中jstl标签的类似 if - else 语句 的语法
  4. 春联c语言,千古绝对过年春节对联80幅
  5. 2019年9月数据库流行度排行:MySQL 强劲增长完成深 V 反转
  6. 性能无敌的HikariCP数据库连接池实战(文末送书)
  7. 从0到1构建支撑企业自动化运维体系
  8. 深层剖析鸿蒙轻内核M核的动态内存如何支持多段非连续性内存
  9. SecSolar:为代码“捉虫”,让你能更专心写代码
  10. 华为云PB级数据库GaussDB(for Redis)揭秘第七期:高斯Redis与强一致