国产99久久精品_欧美日本韩国一区二区_激情小说综合网_欧美一级二级视频_午夜av电影_日本久久精品视频

最新文章專題視頻專題問答1問答10問答100問答1000問答2000關鍵字專題1關鍵字專題50關鍵字專題500關鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關鍵字專題關鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
問答文章1 問答文章501 問答文章1001 問答文章1501 問答文章2001 問答文章2501 問答文章3001 問答文章3501 問答文章4001 問答文章4501 問答文章5001 問答文章5501 問答文章6001 問答文章6501 問答文章7001 問答文章7501 問答文章8001 問答文章8501 問答文章9001 問答文章9501
當前位置: 首頁 - 科技 - 知識百科 - 正文

Vue.js開發一個全局調用的MessageBox組件

來源:懂視網 責編:小采 時間:2020-11-27 20:10:32
文檔

Vue.js開發一個全局調用的MessageBox組件

Vue.js開發一個全局調用的MessageBox組件:前言目前在開發個人博客項目中,一開始就沒準備使用一些現在比較流行的UI庫(畢竟是個人項目,多練練手還是好的),所以需要自己開發幾個全局組件,這里以MessageBox為例記錄下Vue.js如何開發全局組件。源碼Talk is cheap. Show me the code
推薦度:
導讀Vue.js開發一個全局調用的MessageBox組件:前言目前在開發個人博客項目中,一開始就沒準備使用一些現在比較流行的UI庫(畢竟是個人項目,多練練手還是好的),所以需要自己開發幾個全局組件,這里以MessageBox為例記錄下Vue.js如何開發全局組件。源碼Talk is cheap. Show me the code

前言

目前在開發個人博客項目中,一開始就沒準備使用一些現在比較流行的UI庫(畢竟是個人項目,多練練手還是好的),所以需要自己開發幾個全局組件,這里以MessageBox為例記錄下Vue.js如何開發全局組件。

源碼

Talk is cheap. Show me the code.

組件模板

// /src/components/MessageBox/index.vue
<template>
<p class="message-box" v-show="isShowMessageBox">
<p class="mask" @click="cancel"></p>
<p class="message-content">
<svg class="icon" aria-hidden="true" @click="cancel">
<use xlink:href="#icon-delete"></use>
</svg>
<h3 class="title">{{ title }}</h3>
<p class="content">{{ content }}</p>
<p>
<input type="text" v-model="inputValue" v-if="isShowInput" ref="input">
</p>
<p class="btn-group">
<button class="btn-default" @click="cancel" v-show="isShowCancelBtn">{{ cancelBtnText }}</button>
<button class="btn-primary btn-confirm" @click="confirm" v-show="isShowConfimrBtn">{{ confirmBtnText }}</button>
</p>
</p>
</p>
</template>

<script>
export default {
props: {
title: {
type: String,
default: '標題'
},
content: {
type: String,
default: '這是彈框內容'
},
isShowInput: false,
inputValue: '',
isShowCancelBtn: {
type: Boolean,
default: true
},
isShowConfimrBtn: {
type: Boolean,
default: true
},
cancelBtnText: {
type: String,
default: '取消'
},
confirmBtnText: {
type: String,
default: '確定'
}
},
data () {
return {
isShowMessageBox: false,
resolve: '',
reject: '',
promise: '' // 保存promise對象
};
},
methods: {
// 確定,將promise斷定為resolve狀態
confirm: function () {
this.isShowMessageBox = false;
if (this.isShowInput) {
this.resolve(this.inputValue);
} else {
this.resolve('confirm');
}
this.remove();
},
// 取消,將promise斷定為reject狀態
cancel: function () {
this.isShowMessageBox = false;
this.reject('cancel');
this.remove();
},
// 彈出messageBox,并創建promise對象
showMsgBox: function () {
this.isShowMessageBox = true;
this.promise = new Promise((resolve, reject) => {
this.resolve = resolve;
this.reject = reject;
});
// 返回promise對象
return this.promise;
},
remove: function () {
setTimeout(() => {
this.destroy();
}, 300);
},
destroy: function () {
this.$destroy();
document.body.removeChild(this.$el);
}
}
};
</script>
<style lang="scss" scoped>
// 此處省略 ...
</style>

給組件添加全局功能

vue.js官方文檔中有開發插件的介紹。具體實現代碼如下:

// /src/components/MessageBox/index.js

import msgboxVue from './index.vue';
// 定義插件對象
const MessageBox = {};
// vue的install方法,用于定義vue插件
MessageBox.install = function (Vue, options) {
const MessageBoxInstance = Vue.extend(msgboxVue);
let currentMsg;
const initInstance = () => {
// 實例化vue實例
currentMsg = new MessageBoxInstance();
let msgBoxEl = currentMsg.$mount().$el;
document.body.appendChild(msgBoxEl);
};
// 在Vue的原型上添加實例方法,以全局調用
Vue.prototype.$msgBox = {
showMsgBox (options) {
if (!currentMsg) {
initInstance();
}
if (typeof options === 'string') {
currentMsg.content = options;
} else if (typeof options === 'object') {
Object.assign(currentMsg, options);
}
return currentMsg.showMsgBox()
.then(val => {
currentMsg = null;
return Promise.resolve(val);
})
.catch(err => {
currentMsg = null;
return Promise.reject(err);
});
}
};
};
export default MessageBox;

全局使用

// src/main.js
import MessageBox from './components/MessageBox/index';
Vue.use(MessageBox);

頁面調用

按照之前定義好的方法,可以在各個頁面中愉快的調用該組件了。

this.$msgBox.showMsgBox({
title: '添加分類',
content: '請填寫分類名稱',
isShowInput: true
}).then(async (val) => {
// ...
}).catch(() => {
// ...
});

最后來張效果圖

以上內容就是Vue.js開發一個全局調用的MessageBox組件,希望對大家有幫助。

相關推薦:

vue.js父向子組件傳參的實現方法

Vue.js組件通信中的幾種姿勢具體分析

Vue.js常用指令的學習詳解

聲明:本網頁內容旨在傳播知識,若有侵權等問題請及時與本網聯系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

文檔

Vue.js開發一個全局調用的MessageBox組件

Vue.js開發一個全局調用的MessageBox組件:前言目前在開發個人博客項目中,一開始就沒準備使用一些現在比較流行的UI庫(畢竟是個人項目,多練練手還是好的),所以需要自己開發幾個全局組件,這里以MessageBox為例記錄下Vue.js如何開發全局組件。源碼Talk is cheap. Show me the code
推薦度:
標簽: VUE 開發 js
  • 熱門焦點

最新推薦

猜你喜歡

熱門推薦

專題
Top
主站蜘蛛池模板: 亚洲韩精品欧美一区二区三区 | 二区久久国产乱子伦免费精品 | 久久九色综合九色99伊人 | 视频在线观看国产 | 亚洲欧洲日韩综合 | 欧美叉叉 | 国产一级一级一级成人毛片 | 欧美另类在线观看 | 亚洲视频网站在线观看 | 欧美色图亚洲激情 | 国产精品99 | 国产伦精品一区二区三区免费下载 | 国产九九精品 | 精品国产一区二区三区久久影院 | 亚洲欧美日韩在线2020 | 欧美第一精品 | 欧美日本日韩aⅴ在线视频 欧美日韩91 | 国产精品原创视频 | 国产成人精品一区二区免费视频 | 亚洲一区免费观看 | 午夜国产电影 | 中文国产成人精品久久一区 | 国产69精品久久久久99不卡 | 劲爆欧美精品13页 | 国产一区二区三区免费 | 欧美精品第二页 | 国产一页 | 日韩欧美一区二区三区在线视频 | 欧美在线视频在线观看 | 日韩在线小视频 | 欧美日韩成人在线 | 国产激情一区二区三区成人91 | 国产第一夜 | 性欧美xxxx乳高跟 | 精品一区二区三 | 欧美91精品| 91麻豆免费观看 | 一区二区三区在线视频观看 | 台湾一级毛片永久免费 | 性欧美大战久久久久久久野外黑人 | 欧美激情亚洲图片 |