91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

用Vue.extend構建消息提示組件的方法實例

發布時間:2020-10-01 01:57:31 來源:腳本之家 閱讀:148 作者:殤柒 欄目:web開發

前提

前段時間自己做的vue練手項目,需要一個通用的消息提示組件,但是消息提示這種組件我更想用方法來調用,而不是在各個頁面上都添加個組件(那樣感覺很麻煩,重度懶癌患者),于是就上網差查了查,并研究了ElementUI的message源碼。自己弄出來一個簡陋的消息提示組件

Vue.extend是什么

用Vue.extend構建消息提示組件的方法實例

按照官方文檔說法,他是一個類構造器,用來創建一個子類vue并返回構造函數,而Vue.component它的任務是將給定的構造函數與字符串ID相關聯,以便Vue.js可以在模板中接收它。
了解了這點之后我們開始做我們的消息提示組件吧。

消息提示組件

首先我們先創建我們的提示組件的模板

<template>
  <transition name="message-fade">
    <div class="message" v-show="show">
    <span class="icon"><icon name="info"></icon></span>
      <p>{{message}}</p>
    </div>
  </transition>
</template>

<script>
  export default {
    name: 'v-message',
    mounted(){
      this.StartTime();
    },
    data(){
      return {
        message: '123',
        show: false,
        timer: null
      }
    },
    methods:{
      StartTime(){
        this.show = true;
        if(this.timer){
          clearTimeOut(this.timer)
        }else{
          this.timer = setTimeout(()=>{
            this.show = false
          }, 3000);
        }
      }
    }
  }
</script>

之后我們需要用將message.vue傳到Vue.extend()里

import Vue from 'vue';
let MessageBox = Vue.extend(require('./message.vue'));
let instance;
var message = function(options){
  if(typeof options === 'string'){
    options = {
      message: options
    }
  }
  //生成組件
  instance = new MessageBox({
    data: options
  })
  //組件需要掛載在dom元素上
  instance.vm = instance.$mount();
  //根據不同的類型,設置不同消息的背景顏色
  if(options.type){
    instance.vm.$el.children[0].className += ` icon__${options.type}`;
  }
  document.body.appendChild(instance.vm.$el);
  return instance.vm;
}

const type = ['success', 'info', 'warning', 'error'];
type.forEach((type)=>{
  message[type] = options =>{
    if(typeof options === 'string'){
      options = {
        message: options
      }
    }
    options.type = type;
    return message(options);
  }
})

export default message;

之后用掛在全局方法上,之后用this.$message()方法調用

vue.prototype.$message = message;

最后的效果圖

用Vue.extend構建消息提示組件的方法實例

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持億速云。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

英山县| 扶绥县| 江源县| 黄大仙区| 临邑县| 宣汉县| 深州市| 茶陵县| 班玛县| 哈密市| 广平县| 花莲县| 旺苍县| 阳山县| 中阳县| 兴海县| 天全县| 呼伦贝尔市| 永兴县| 盱眙县| 县级市| 同江市| 沾益县| 怀来县| 临澧县| 潼关县| 汝城县| 年辖:市辖区| 林口县| 巫溪县| 石首市| 贵定县| 镇巴县| 吴旗县| 门源| 广水市| 阿克苏市| 江达县| 景谷| 阳山县| 涟水县|