亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > JavaScript > 正文

vue項目中仿element-ui彈框效果的實例代碼

2019-11-19 11:44:01
字體:
來源:轉載
供稿:網友

最近要寫個彈框,發現element-ui彈框樣式還可以,就copy下來改吧改吧。也不分步驟詳細介紹了直接上代碼。

在組件目錄中新建文件夾message

我把message目錄里的東西給大家貼出來

message文件夾

src文件夾

index.js

import Message from './src/main.js';export default Message;

mian.js

import Vue from 'vue';import Main from './main.vue';let MessageConstructor = Vue.extend(Main);let instance;let instances = [];let seed = 1;const Message = (options = {}) => { if (typeof options === 'string') { options = {  message: options }; } let userOnClose = options.onClose; let id = 'message_' + seed++; options.onClose = function() { Message.close(id, userOnClose); }; instance = new MessageConstructor({ data: options }); instance.id = id; instance.vm = instance.$mount(); document.body.appendChild(instance.vm.$el); instance.vm.visible = true; instance.dom = instance.vm.$el; instance.dom.style.zIndex = 999; instances.push(instance); return instance.vm;}['success', 'warning', 'info', 'error'].forEach(type => { Message[type] = options => { if (typeof options === 'string') {  options = {  message: options  }; } options.type = type; return Message(options); };});Message.close = function(id, userOnClose) { for (let i = 0, len = instances.length; i < len; i++) { if (id === instances[i].id) {  if (typeof userOnClose === 'function') {  userOnClose(instances[i]);  }  instances.splice(i, 1);  break; } }};Message.closeAll = function() { for (let i = instances.length - 1; i >= 0; i--) { instances[i].close(); }};export default Message;

mian.vue

<template> <transition name="message-fade">  <div :class="[   'message',   type && !iconClass ? `message-${ type }` : '',   center ? 'center' : '',   showClose ? 'closable' : '',   customClass   ]"    v-show="visible"    @mouseenter="clearTimer"    @mouseleave="startTimer">   <i :class="iconClass" v-if="iconClass"></i>   <i :class="typeClass" v-else></i>   <slot>    <p v-if="!dangerouslyUseHTMLString" class="message-content">{{ message }}</p>    <p v-else v-html="message" class="message-content"></p>   </slot>   <i v-if="showClose" class="message-close-btn icon-close" @click="close"></i>  </div> </transition></template><script> const typeMap = { success: 'success', info: 'info', warning: 'warning', error: 'error' }; export default { data () {  return {  visible: false,  message: '',  duration: 1000,  type: 'info',  iconClass: '',  customClass: '',  onClose: null,  showClose: false,  closed: false,  timer: null,  dangerouslyUseHTMLString: false,  center: false  } }, computed: {  typeClass() {  return this.type && !this.iconClass   ? `message-icon icon-${ typeMap[this.type] }`   : '';  } }, watch: {  closed(newVal) {  if (newVal) {   this.visible = false;   this.$el.addEventListener('transitionend', this.destroyElement);  }  } }, methods: {  destroyElement() {  this.$el.removeEventListener('transitionend', this.destroyElement);  this.$destroy(true);  this.$el.parentNode.removeChild(this.$el);  },  close() {  this.closed = true;  if (typeof this.onClose === 'function') {   this.onClose(this);  }  },  clearTimer() {  clearTimeout(this.timer);  },  startTimer() {  if (this.duration > 0) {   this.timer = setTimeout(() => {   if (!this.closed) {    this.close();   }   }, this.duration);  }  },  keydown(e) {  if (e.keyCode === 27) { // esc關閉消息   if (!this.closed) {   this.close();   }  }  } }, mounted() {  this.startTimer();  document.addEventListener('keydown', this.keydown); }, beforeDestroy() {  document.removeEventListener('keydown', this.keydown); } }</script><style lang="less"> .message {  min-width: 200px;  box-sizing: border-box;  border-radius: 3px;  border: 1px solid #ebeef5;  position: fixed;  left: 50%;  top: 20px;  transform: translateX(-50%);  background-color: #edf2f3;  transition: opacity 0.3s, transform .4s;  overflow: hidden;  padding: 10px;  display: flex;  align-items: center; } .message-icon{  width: 15px;  height: 15px;  border-radius: 100%;  background: #fff;  display: inline-block;  margin-right: 10px;  &.icon-success{   background: url("../../../assets/image/icon-success.png") no-repeat center center;   background-size: auto 100%;  }  &.icon-error{   background: url("../../../assets/image/icon-error.png") no-repeat center center;   background-size: auto 100%;  }  &.icon-info{   background: url("../../../assets/image/icon-info.png") no-repeat center center;   background-size: auto 100%;  }  &.icon-warning{   background: url("../../../assets/image/icon-warning.png") no-repeat center center;   background-size: auto 100%;  } } .message-success{  background: #f2f8ec;  border-color: #e4f2da;  .message-content{   color: #7ebe50;  } } .message-error{  background: #fcf0f0;  border-color: #f9e3e2;  .message-content{   color: #e57470;  } } .message-warning{  background: #fcf6ed;  border-color: #f8ecda;  .message-content{   color: #dca450;  } } .message-info{  background: #eef2fb;  border-color: #ebeef4;  .message-content{   color: #919398;  } } .message-fade-enter, .message-fade-leave-active {  opacity: 0;  transform: translate(-50%, -100%); }</style>

以上就是封裝的所有代碼
 接下來就來看看如何引用

main.js中引入

import Message from '@/components/message/index.js'

Vue.prototype.$message = Message

調用

在你需要的頁面調用

this.$message({  message: '提示消息',  type:'error' //type有四個值 1.error 2.success 3.info 4.warning});

type為success

type為warning

type為info

type為errpr

小icon的圖片用自己的圖片哦

總結

以上所述是小編給大家介紹的vue項目中仿element-ui彈框效果的實例代碼,希望對大家有所幫助,如果大家有任何疑問歡迎給我留言,小編會及時回復大家的!

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产精品福利无圣光在线一区| 91中文精品字幕在线视频| 欧美日韩在线观看视频| 国产精品久久久久久久久久久不卡| 亚洲综合中文字幕在线| 亚洲国产精品yw在线观看| 欧美性猛交xxxxx免费看| 欧美成人黑人xx视频免费观看| 97人人模人人爽人人喊中文字| 欧美国产日韩一区二区三区| 国产亚洲精品久久久久久777| xxxxx91麻豆| 欧美成年人视频网站欧美| 亚洲第一精品夜夜躁人人躁| 91经典在线视频| 日韩欧亚中文在线| 成人免费福利视频| 91精品在线观看视频| 久久久噜噜噜久久久| 亚洲一区二区精品| 成人欧美在线观看| 狠狠色狠狠色综合日日小说| 国产九九精品视频| 久久久久久久成人| 亚洲区在线播放| 久久99国产精品自在自在app| 欧美激情成人在线视频| 日韩美女在线播放| 91伊人影院在线播放| 77777亚洲午夜久久多人| 国模gogo一区二区大胆私拍| 97在线视频观看| 日韩经典中文字幕| 亚洲有声小说3d| 国产成人精品av| 在线观看国产精品91| 国产丝袜一区视频在线观看| 国产精品久久久久久影视| 国产一区二区三区日韩欧美| 欧美视频在线观看免费网址| 国产香蕉97碰碰久久人人| 精品国产91久久久| 91地址最新发布| 亚洲成人av中文字幕| 亚洲人线精品午夜| 亚洲免费av电影| 91av福利视频| 国产亚洲欧洲在线| www.久久撸.com| 91亚洲精品久久久| 91在线视频免费| 国产亚洲日本欧美韩国| 91精品国产91久久久| 欧美一级淫片播放口| 九九视频直播综合网| 欧美精品在线免费| 日本精品中文字幕| 91国产美女视频| 亚洲bt天天射| 国产欧美一区二区三区在线看| 国产欧美va欧美va香蕉在线| 国产精品一区av| 国产精品国产自产拍高清av水多| 91av在线免费观看| 亚洲最新在线视频| 午夜伦理精品一区| 午夜欧美不卡精品aaaaa| 精品女厕一区二区三区| 2021久久精品国产99国产精品| 久久影院资源站| 91在线观看免费高清完整版在线观看| 欧美国产一区二区三区| 日韩高清欧美高清| 亚洲第一福利网| 亚洲国产精品人人爽夜夜爽| 亚洲福利视频久久| 色偷偷噜噜噜亚洲男人的天堂| 欧美激情视频一区二区| 欧美成人精品不卡视频在线观看| 国产精品一区二区av影院萌芽| 欧美日韩性生活视频| 久久久久久97| 欧美日韩成人在线视频| 欧美日韩xxx| 久久久久在线观看| 亚洲精品www久久久久久广东| 97成人在线视频| 一区二区三区回区在观看免费视频| 色777狠狠综合秋免鲁丝| 久久久精品网站| 日韩av在线播放资源| 亚洲色图色老头| 久久精品国产精品| 国产精品入口夜色视频大尺度| 日韩精品在线观看网站| 成人网址在线观看| 国产亚洲精品久久| 日韩在线免费观看视频| 日韩中文字幕国产精品| 国产精品丝袜久久久久久不卡| 欧美在线不卡区| 九九热99久久久国产盗摄| 一区二区三区日韩在线| 在线观看精品国产视频| 日韩精品免费在线视频观看| 日韩av中文字幕在线播放| 亚洲国语精品自产拍在线观看| 久久这里有精品视频| 在线电影中文日韩| 国产一区二区三区在线播放免费观看| 欧美二区在线播放| 日韩欧美精品中文字幕| 亚洲三级免费看| 青青久久av北条麻妃黑人| 精品久久久久久久久久| 在线播放日韩专区| 久久国产精品久久久久久久久久| 日韩精品视频中文在线观看| 亚洲精品久久在线| 国产精品视频一区国模私拍| 久久久久久久久久久91| 国产精品国产三级国产专播精品人| 亚洲日本成人女熟在线观看| 色阁综合伊人av| 久久久久久一区二区三区| 国产视频综合在线| 精品久久久香蕉免费精品视频| 久久国产加勒比精品无码| 日本欧美精品在线| zzijzzij亚洲日本成熟少妇| 久久综合九色九九| 精品国偷自产在线视频99| 精品成人国产在线观看男人呻吟| 久久久久久久久爱| 亚洲成人免费网站| 一区二区欧美激情| 亚洲色图欧美制服丝袜另类第一页| 欧美日韩福利电影| 日韩av中文字幕在线| 欧美激情综合色| 国产精品视频永久免费播放| 亚洲欧美一区二区精品久久久| 久久精品福利视频| 亚洲欧美中文字幕| 夜夜躁日日躁狠狠久久88av| 亚洲伦理中文字幕| 久久久噜噜噜久久久| 欧美视频裸体精品| 日韩欧美在线观看| 91在线高清免费观看| 久久精品中文字幕一区| 91精品国产高清久久久久久91| 国产一区私人高清影院| 日韩av中文字幕在线| 正在播放欧美一区| 成人中文字幕+乱码+中文字幕| 国产精品国产三级国产aⅴ浪潮| 狠狠色狠狠色综合日日五| 91九色国产社区在线观看| 久久久中文字幕| 色综合色综合久久综合频道88| 91精品91久久久久久| 秋霞av国产精品一区| 91亚洲国产成人久久精品网站|