欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Vue.extend 登錄注冊模態(tài)框的實現(xiàn)

 更新時間:2020年12月29日 10:36:44   作者:Mondo  
這篇文章主要介紹了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.vueRegister.vue 兩個組件,然后把兩個組件寫入 App.vue 組件中,或者是 layout.vue 組件中。

原來的這種使用,對于我們的整塊的登錄注冊邏輯是分散的,一些需要登錄或者是權限的邏輯,可能都需要特意去提取一個 Visible 來控制我們的登錄框。

使用 Vue.extend 可以達到統(tǒng)一接口,不用邏輯分散,下面的示例,僅作參考,不了解該 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>

創(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.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,
  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的先后順序說明

    這篇文章主要介紹了vue.js頁面加載執(zhí)行created,mounted的先后順序說明,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-11-11
  • Vue生產和開發(fā)環(huán)境如何切換及過濾器的使用

    Vue生產和開發(fā)環(huán)境如何切換及過濾器的使用

    本文主要介紹了Vue生產、開發(fā)環(huán)境如何切換及過濾器的使用,文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-08-08
  • vue3通過父子傳值實現(xiàn)彈框功能

    vue3通過父子傳值實現(xiàn)彈框功能

    在Vue3中,我們可以通過?provide?和?inject?來實現(xiàn)父子組件之間的數(shù)據(jù)傳遞,這也適用于實現(xiàn)彈框功能,下面我們就來學習一下vue3實現(xiàn)彈框功能的具體方法吧
    2023-12-12
  • vue?頁面刷新、重置、更新頁面所有數(shù)據(jù)的示例代碼

    vue?頁面刷新、重置、更新頁面所有數(shù)據(jù)的示例代碼

    Vue.js提供了多種方式來實現(xiàn)頁面刷新、重置和更新頁面所有數(shù)據(jù)的功能,下面通過示例代碼演示vue?頁面刷新、重置、更新頁面所有數(shù)據(jù),感興趣的朋友跟隨小編一起看看吧
    2024-01-01
  • vue?cli+axios踩坑記錄+攔截器使用方式,代理跨域proxy

    vue?cli+axios踩坑記錄+攔截器使用方式,代理跨域proxy

    這篇文章主要介紹了vue?cli+axios踩坑記錄+攔截器使用方式,代理跨域proxy,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-04-04
  • Vue組件通信入門之Provide和Inject機制

    Vue組件通信入門之Provide和Inject機制

    這篇文章主要給大家介紹了關于Vue組件通信入門之Provide和Inject機制的相關資料,文中通過示例代碼介紹的非常詳細,對大家學習或者使用Vue組件通信具有一定的參考學習價值,需要的朋友們下面來一起學習學習吧
    2019-12-12
  • vue-cli的eslint相關用法

    vue-cli的eslint相關用法

    本篇文章主要介紹了vue-cli的eslint相關用法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-09-09
  • vue實現(xiàn)拖拽窗口功能

    vue實現(xiàn)拖拽窗口功能

    這篇文章主要為大家詳細介紹了vue實現(xiàn)拖拽窗口功能,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-04-04
  • v-distpicker地區(qū)選擇器組件使用實例詳解

    v-distpicker地區(qū)選擇器組件使用實例詳解

    代碼添加了一個vDistpickerHandle的事件處理函數(shù)對地區(qū)選擇器中的數(shù)據(jù)進行處理,將數(shù)據(jù)存儲到form對象的相應屬性中,方便數(shù)據(jù)提交,這篇文章主要介紹了v-distpicker地區(qū)選擇器組件使用,需要的朋友可以參考下
    2024-02-02
  • vue-cli中設置publicPath的幾種方式對比

    vue-cli中設置publicPath的幾種方式對比

    這篇文章主要介紹了vue-cli中設置publicPath的幾種方式對比,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-07-07

最新評論