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

f9706a5afd382eef52dcd92810b02550.gif

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

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

3824a34514cf7c9b7676d8796773fdd8.png

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

我们对于这种常见的登录注册业务,一般都是分为 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); // 将模态框添加至 body
return instance;
};

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

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

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

复制代码

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

// main.js
import LoginModal from "./components/LoginModal";

Vue.use(LoginModal);
复制代码

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

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


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

效果如下

4a6b2db5e060129cee04199a6f3a94d2.gif

验证事件

我们都知道模态框需要关闭事件,而像这种业务的关闭事件必然是需要验证提交信息,所以我们需要加上关闭回调函数。
修改 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();
}
});
}
});
}
复制代码

效果如下

b3eae154ea4ba8a33de790b9fe2b94b1.gif

a9e1a752479e66c5ce66a33e363f3808.gif

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值