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

Vue自定義toast組件的實例代碼

 更新時間:2018年08月15日 11:52:58   作者:居居三連  
這篇文章主要介紹了Vue自定義toast組件的相關(guān)資料,需要的朋友可以參考下

寫了兩三天,終于把toast組件寫出來了。不敢說是最好的設(shè)計,希望有更好思路的朋友可以在評論區(qū)給我意見!_(:з」∠)_

第一步:寫toast.vue,將樣式之類的先定下來

<template>
 <div v-show="showToast" class="toast" :class="position">
 <div class="toast_container" v-if="type=='success'">
  <div><i class="iconfont icon-check icon"></i></div>
  <div class="msg_container">{{message}}</div>
 </div>
 <div class="toast_container" v-else-if="type=='wrong'">
  <div><i class="iconfont icon-warning-circle icon"></i></div>
  <div class="msg_container">{{message}}</div>
 </div>
 <div class="toast_container" v-else-if="type=='loading'">
  <div><loading10></loading10></div>
  <div class="msg_container">{{message}}</div>
 </div>
</div>
</template>
<script>
import loading10 from '../loading/spiner'
export default{
 props:{
  message:String,
  type:{
   validator: function (value) {
   // 值必須是這些字符串中的一個
   return ['success', 'wrong', 'loading'].indexOf(value) !== -1
  },
   default:'success'
  },
  duration:{
   type:Number,
   default:3000
  },
   position:{
   type:String,
   default:'middle'
  }
 },
 components:{
  loading10
 },
 data(){
  return{
   showToast:false
  }
 }
}
</script>
<style scoped>
.toast{
 width:100%;
}
.toast_container{
 background: rgba(0, 0, 0, 0.7);
 border-radius: 8px;
 color:#fff;
 margin-left:88px;
 margin-right:88px;
 text-align:center;
 padding-top:15px;
 padding-bottom: 15px; 
}
.top{
 position:absolute;
 top:10%;
}
.middle{
 position:absolute;
 top:40%;
}
.bottom{
 position:absolute;
 top:70%;
}
.msg_container{
 margin-top:8px;
 margin-left:15px;
 margin-right:15px;
 line-height: 22px;
 font-size: 16px;
 word-wrap: break-word;
}
.icon{
 font-size:30px;
}
</style>

一共三種樣式,成功(success),失?。╳rong),加載中(loading);

一共三種位置,上(top),中(middle),下(bottom);

所有涉及的圖案出自阿里的iconfont 手機淘寶圖標(biāo)庫。

加載中動畫是自己寫的蹩腳的加載組件(emmm,就不放出來污染大家眼睛了,需要的可以評論區(qū)知會一聲_(:з」∠)_)

第二步:寫index.js ,完成toast組件的實例化

import Vue from 'vue'
import Toast from './toast'
let singleToast=true;
let queue=[];
function createInstance(){
 // 返回一個擴展實例構(gòu)造器
 if(!queue.length||!singleToast){
 const ToastConstructor = Vue.extend(Toast);
 // 構(gòu)造一個實例
 const toastDom = new ToastConstructor({
 el: document.createElement('div'),
 });
 // 把實例化的 toast.vue 添加到 body 里
 document.body.appendChild(toastDom.$el);
 queue.push(toastDom);
 singleToast=true;
 return toastDom;
 }
};
// 注冊為全局組件的函數(shù)
function toast(options= {}) {
 const toastDom = createInstance();
 toastDom.message =typeof options === 'string' ? options : options.message;
 toastDom.type = options.type || 'success';
 toastDom.duration = options.duration || 3000;
 toastDom.position = options.position || 'middle';
 if(!toastDom.message){
 toastDom.showToast =singleToast= false;
 }else{
 toastDom.showToast=true;
 setTimeout(() => {toastDom.showToast =singleToast= false} ,toastDom.duration);
 }
}
// 將組件注冊到 vue 的 原型鏈里去,
// 這樣就可以在所有 vue 的實例里面使用 this.$toast()
// Vue.prototype.$toast = showToast
Vue.prototype.$toast = toast;
export default toast

設(shè)置singleToast和queue的目的在于:確保同一時期界面上只有一個toast,不能同時出現(xiàn)多個toast。

由于toast會初始化,因此為了避免在任何操作之前界面上就出現(xiàn)一個toast,用if語句判斷:

如果沒有傳入的message,則不顯示toast(這樣可以使得初始化的toast不顯示)

否則顯示,并且過一定時間消失,只有singleToast為false,說明此刻界面上沒有toast,才能再新建一個toast實例(因為此時if判斷內(nèi)queue.length 不為0【初始化的toast組件本身占了一個位置】,而singleToast為false,因此可以創(chuàng)建)

第三步:使用

在main.js 添加如下代碼:

import toast from './components/toast/index'
Vue.use(toast)

創(chuàng)建需要調(diào)用的Vue文件:

<template>
 <div>
  <input type="button" value="顯示彈窗" @click="showToast">
 </div>
</template>
 <script>
 export default {
  methods: {
   showToast () {
    this.$toast({message:'加載中',type:'loading',position:'bottom',
     duration:'2000'});
    // this.$toast('成功提示');
   }
  }
 }
 </script>

可以看到一共兩種方式,可以以對象方式傳入?yún)?shù),也可以只傳入字符串,其他采用默認(rèn)設(shè)置。

總結(jié)

以上所述是小編給大家介紹的SVue自定義toast組件的實例代碼,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!

相關(guān)文章

  • vue 實現(xiàn)移動端鍵盤搜索事件監(jiān)聽

    vue 實現(xiàn)移動端鍵盤搜索事件監(jiān)聽

    今天小編就為大家分享一篇vue 實現(xiàn)移動端鍵盤搜索事件監(jiān)聽,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-11-11
  • vue項目打包以及優(yōu)化的實現(xiàn)步驟

    vue項目打包以及優(yōu)化的實現(xiàn)步驟

    項目完成,我們會將項目進行上線,為了提升性能,我們往往會進行一些優(yōu)化處理,本文主要介紹了vue項目打包以及優(yōu)化的實現(xiàn)步驟,感興趣的可以了解一下
    2021-07-07
  • vue計時器的實現(xiàn)方法

    vue計時器的實現(xiàn)方法

    這篇文章主要為大家詳細(xì)介紹了vue計時器的實現(xiàn)方法,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-06-06
  • vue router總結(jié) $router和$route及router與 router與route區(qū)別

    vue router總結(jié) $router和$route及router與 router與route區(qū)別

    這篇文章主要介紹了vue router總結(jié) $router和$route及router與 router與route區(qū)別,本文給大家介紹的非常詳細(xì),具有一定的參考借鑒價值 ,需要的朋友可以參考下
    2019-07-07
  • Vue.js實現(xiàn)無限加載與分頁功能開發(fā)

    Vue.js實現(xiàn)無限加載與分頁功能開發(fā)

    這篇文章主要為大家詳細(xì)介紹了Vue.js實現(xiàn)無限加載與分頁功能開發(fā)實踐,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2016-11-11
  • Vue3警告:Failed to resolve component:XXX的詳細(xì)解決辦法

    Vue3警告:Failed to resolve component:XXX的詳細(xì)解決辦法

    最近在一個vue3項目中遇到了報錯,整理了些解決辦法,這篇文章主要給大家介紹了關(guān)于Vue3警告:Failed to resolve component:XXX的詳細(xì)解決辦法,文中介紹的非常詳細(xì),需要的朋友可以參考下
    2023-05-05
  • 淺談vue中$bus的使用和涉及到的問題

    淺談vue中$bus的使用和涉及到的問題

    這篇文章主要介紹了淺談vue中$bus的使用和涉及到的問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-07-07
  • Vue Element前端應(yīng)用開發(fā)之echarts圖表

    Vue Element前端應(yīng)用開發(fā)之echarts圖表

    在我們做應(yīng)用系統(tǒng)的時候,往往都會涉及圖表的展示,綜合的圖表展示能夠給客戶帶來視覺的享受和數(shù)據(jù)直觀體驗,同時也是增強客戶認(rèn)同感的舉措之一
    2021-05-05
  • 利用Vue實現(xiàn)將圖片轉(zhuǎn)換為Base64編碼的方法

    利用Vue實現(xiàn)將圖片轉(zhuǎn)換為Base64編碼的方法

    這篇文章主要介紹了利用Vue實現(xiàn)將圖片轉(zhuǎn)換為Base64編碼的方法,Base64是一種編碼方式,用于將二進制數(shù)據(jù)轉(zhuǎn)換成64個基于ASCII的可打印字符,這種編碼可嵌入圖像到HTML或CSS中,減少加載時間,解決跨域問題,并支持離線應(yīng)用開發(fā),需要的朋友可以參考下
    2024-10-10
  • vue腳手架項目創(chuàng)建步驟詳解

    vue腳手架項目創(chuàng)建步驟詳解

    這篇文章主要介紹了vue腳手架項目創(chuàng)建步驟詳解,文章講解的很清晰,初學(xué)者可以跟著步驟學(xué)習(xí)下
    2021-03-03

最新評論