1. 程式人生 > 程式設計 >Vue.extend 登入註冊模態框的實現

Vue.extend 登入註冊模態框的實現

模態框是我們 UI 控制元件中一個很重要的元件,使用場景有很多種,我們在 Vue 元件中建立模態框元件而用到的一個知識點是利用 Vue.extend 來建立。

文件中的解釋是

Vue.extend 登入註冊模態框的實現

在最近在做一個常用的類似下面的 登入/註冊 業務場景時,利用 Vue.extend 來改善我們的程式碼,使我們程式碼邏輯更清晰化。

Vue.extend 登入註冊模態框的實現

需求:點選登入或註冊出現各自的模態框。

我們對於這種常見的登入註冊業務,一般都是分為 Sigin.vueRegister.vue 兩個元件,然後把兩個元件寫入 App.vue 元件中,或者是 layout.vue 元件中。

原來的這種使用,對於我們的整塊的登入註冊邏輯是分散的,一些需要登入或者是許可權的邏輯,可能都需要特意去提取一個 Visible

來控制我們的登入框。

使用 Vue.extend 可以達到統一介面,不用邏輯分散,下面的示例,僅作參考,不瞭解該 api 使用的可以瞭解下,而瞭解的,歡迎指導:smiley:

元件

新建 LoginModel 目錄,新建 Sigin.vueRegister.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
 })
}

效果如下

Vue.extend 登入註冊模態框的實現

驗證事件

我們都知道模態框需要關閉事件,而像這種業務的關閉事件必然是需要驗證提交資訊,所以我們需要加上關閉回撥函式。

修改 Sigin.vueRegister.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,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 登入註冊模態框的實現的文章就介紹到這了,更多相關Vue.extend 登入註冊模態框內容請搜尋我們以前的文章或繼續瀏覽下面的相關文章希望大家以後多多支援我們!