Vue.extend 登錄注冊模態(tài)框的實現(xiàn)
模態(tài)框是我們 UI
控件中一個很重要的組件,使用場景有很多種,我們在 Vue 組件中創(chuàng)建模態(tài)框組件而用到的一個知識點是利用 Vue.extend
來創(chuàng)建。
文檔中的解釋是
在最近在做一個常用的類似下面的 登錄/注冊
業(yè)務場景時,利用 Vue.extend
來改善我們的代碼,使我們代碼邏輯更清晰化。
需求:點擊登錄或注冊出現(xiàn)各自的模態(tài)框。
我們對于這種常見的登錄注冊業(yè)務,一般都是分為 Sigin.vue
和 Register.vue
兩個組件,然后把兩個組件寫入 App.vue 組件中,或者是 layout.vue
組件中。
原來的這種使用,對于我們的整塊的登錄注冊邏輯是分散的,一些需要登錄或者是權限的邏輯,可能都需要特意去提取一個 Visible
來控制我們的登錄框。
使用 Vue.extend
可以達到統(tǒng)一接口,不用邏輯分散,下面的示例,僅作參考,不了解該 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>
創(chuàng)建子類
新建 index.js
,導入我們的 index.vue
import Vue from "vue"; import ModalCops from "./index.vue"; const LoginModal = Vue.extend(ModalCops); // 創(chuàng)建 Vue 子類 let instance; const ModalBox = (options = {}) => { if (instance) { instance.doClose(); } // 實例化 instance = new LoginModal({ data: { show: true, // 實例化后顯示 ...options } }); instance.$mount(); document.body.appendChild(instance.$el); // 將模態(tài)框添加至 body return instance; }; // 對應的登錄 ModalBox.sigin = () => { return ModalBox({ type: "sigin" }); }; ModalBox.register = () => { return ModalBox({ type: "register" }); }; export default { install(Vue) { Vue.prototype.$loginer = ModalBox; } };
創(chuàng)建完成后,我們可以在入口掛載到 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 }) }
效果如下
驗證事件
我們都知道模態(tài)框需要關閉事件,而像這種業(yè)務的關閉事件必然是需要驗證提交信息,所以我們需要加上關閉回調函數(shù)。
修改 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 驗證數(shù)據(jù)是否正確 if (this.isOk) { funcs[type](); resolve(); } else { reject(); } }); } }); }
效果如下
本文代碼地址
到此這篇關于Vue.extend 登錄注冊模態(tài)框的實現(xiàn)的文章就介紹到這了,更多相關Vue.extend 登錄注冊模態(tài)框內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
vue.js頁面加載執(zhí)行created,mounted的先后順序說明
這篇文章主要介紹了vue.js頁面加載執(zhí)行created,mounted的先后順序說明,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-11-11Vue生產和開發(fā)環(huán)境如何切換及過濾器的使用
本文主要介紹了Vue生產、開發(fā)環(huán)境如何切換及過濾器的使用,文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2021-08-08vue?頁面刷新、重置、更新頁面所有數(shù)據(jù)的示例代碼
Vue.js提供了多種方式來實現(xiàn)頁面刷新、重置和更新頁面所有數(shù)據(jù)的功能,下面通過示例代碼演示vue?頁面刷新、重置、更新頁面所有數(shù)據(jù),感興趣的朋友跟隨小編一起看看吧2024-01-01vue?cli+axios踩坑記錄+攔截器使用方式,代理跨域proxy
這篇文章主要介紹了vue?cli+axios踩坑記錄+攔截器使用方式,代理跨域proxy,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-04-04