模态框是我们 UI 控件中一个很重要的组件,使用场景有很多种,我们在 Vue 组件中创建模态框组件而用到的一个知识点是利用 Vue.extend 来创建。
文档中的解释是
在最近在做一个常用的类似下面的 登录/注册 业务场景时,利用 Vue.extend 来改善我们的代码,使我们代码逻辑更清晰化。
需求:点击登录或注册出现各自的模态框。
我们对于这种常见的登录注册业务,一般都是分为 Sigin.vue 和 Register.vue 两个组件,然后把两个组件写入 App.vue 组件中,或者是 layout.vue 组件中。
原来的这种使用,对于我们的整块的登录注册逻辑是分散的,一些需要登录或者是权限的逻辑,可能都需要特意去提取一个 Visible 来控制我们的登录框。
使用 Vue.extend 可以达到统一接口,不用逻辑分散,下面的示例,仅作参考,不了解该 api 使用的可以了解下,而了解的,欢迎指导:smiley:
新建 LoginModel 目录,新建 Sigin.vue 和 Register.vue 两个组件
<template> <div>登录</div> </template> <template> <div>注册</div> </template>
再新建 index.vue 组件
<template> <div v-if="show"> <Sigin v-if="type === 'sigin'" @sigin="loginCallback" /> <Register v-if="type === 'register'" @register="loginCallback" /> </div> </template> <script> import Sigin from "./sigin"; import Register from "./register"; export default { components: { Register, Sigin }, data() { return { show: false, type: "sigin" }; } }; </script>
新建 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);
在需要登录/注册的地方只用调用
<div> <a href="javascript:;" rel="external nofollow" rel="external nofollow" @click="onLogin('sigin')">登录</a> / <a href="javascript:;" rel="external nofollow" rel="external nofollow" @click="onLogin('register')">注册</a> </div> onLogin(type) { this.$loginer({ type }) }
效果如下
我们都知道模态框需要关闭事件,而像这种业务的关闭事件必然是需要验证提交信息,所以我们需要加上关闭回调函数。
修改 Sigin.vue 和 Register.vue 两个组件,添加事件
// Sigin.vue <template> <div> <button @click="onClick">登录确认</button> </div> </template> <script> export default { name: "Sigin", methods: { onClick() { this.$emit("sigin"); } } }; </script> // Register.vue <template> <button @click="onClick">注册确认</button> </template> <script> export default { name: "Register", methods: { onClick() { this.$emit("register"); } } }; </script>
修改 index.vue 添加 $emit 事件
<template> <div v-if="show"> <Sigin v-if="type === 'sigin'" @sigin="loginCallback" /> <Register v-if="type === 'register'" @register="loginCallback" /> </div> </template> <script> 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; } } }; </script>
修改 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(); } }); } }); }
效果如下
本文代码地址
到此这篇关于Vue.extend 登录注册模态框的实现的文章就介绍到这了,更多相关Vue.extend 登录注册模态框内容请搜索小牛知识库以前的文章或继续浏览下面的相关文章希望大家以后多多支持小牛知识库!
本文向大家介绍Yii2框架实现注册和登录教程,包括了Yii2框架实现注册和登录教程的使用技巧和注意事项,需要的朋友参考一下 注册 在advanced模板中,进入frontend/index.php?r=site%2Fsignup页面,可以看到框架的注册页面 填写完Username、Email和Password后点击Signup后,如果格式不对,frontend/models/SignuForm中的
如果你已有幕布,直接登录即可。如果还没有账号,可以使用手机号码注册幕布账号,也可以通过QQ、微信直接注册并登录。 注:微信登录方式需要手机上安装有微信。 账号设置与绑定 登录幕布后,点左上角的头像或者轻按屏幕从左往右滑动,选择「应用设置 - 账号设置」。在这里可以修改头像和昵称,设置密码,绑定手机号码、微信、QQ账号。 注: 绑定手机后才可以设置账号密码,手机号即为账号。 解除绑定需要在电脑上登录
在首页点击注册进入注册页面,你可以使用手机号码注册幕布账号,也可以通过QQ、微信账户直接创建账号并登录。 账号设置与绑定 登录幕布后,点击右上角处用户头像,在下拉菜单中选择「账号设置」。在这里可以修改头像和昵称,设置密码,绑定手机号码、微信、QQ账号,查看账号是否为高级版以及高级版到期时间。 注: 绑定手机后才可以设置账号密码,手机号即为账号。 解绑最后一个登录方式后,账号将无法登录,请注意将文档
注册 / 登录 1.注册 注册入口: 访问 http://www.aikf.com/ 点击右上角注册按钮 输入注册手机号、图形验证码、手机验证码等进行注册 其他注册入口:手机登录http:/www.aikf.com/ 爱客服官方微信公众号注册:点击立即注册 2.登录 登录入口: 访问http://www.aikf.com/ 点击登录 输入用户名及登录密码,点击登录(见下图) 2.修改密码 在登录入
外业精灵启动的时候,会弹出账号登陆。账号为图新账号,可通用于中科图新旗下所有产品,包括:外业精灵、LSV、wish3D Earth等产品。因此,如果有LSV或者wish3D账号的话,则可以直接在外业精灵进行登录。 账号注册 登陆页面,点击快速注册,会转到注册页: 输入手机号,点击获取验证码,会收到注册短信。填写验证码后,输入密码,即可完成注册。
注册厂商账号 打开浏览器访问注册页面 填写正确的邮箱地址后,点击"获取验证码"按钮,系统将自动发送带有注册验证码的邮件.填写验证码和后续的必要信息后,点击注册按钮,完成注册流程. 登录账号 注册成功后,浏览器将自动跳转到登录页面 填写公司名\密码和验证后.登录
要想使用本系统,请先注册。单击网站主页上方的“免费注册”菜单,即可进入注册页面。 系统目前只支持手机号注册,输入手机号及图片验证码,单击发送验证码,系统将会给你的手机发送一条短信,请将短信输入到短信验证码框中。 同时您还需要输入一个昵称,作为您在网站的显示名称。这个昵称不能和其他用户重复。 最后输入您的登录密码,单击免费注册即可加入地图者的使用行列。 单击主页的“免费试用”按钮或者网页上方的“登录