vue制作全局loading

最近做項(xiàng)目的時(shí)候,發(fā)現(xiàn)自定義loading組件逐虚,發(fā)現(xiàn)網(wǎng)上的loading組件主要有兩種情況:

1.是組件開發(fā)聋溜,這樣開發(fā)需要在引用的地方都要引入一遍,感覺比較麻煩叭爱。

 <template>
     <div class="loading">
       <img width="24" height="24" src="./loading.gif">
       <p class="desc">{{title}}</p>
     </div>
</template>
<script type="text/ecmascript-6">
   export default {
       props: {
           title: {
             type: String,
             default: '正在載入...'
           }
     }
 }
</script>
<style scoped>
 .loading{
   width: 100%;
   text-align: center;
  }
 .desc{
   line-height: 20px;
   font-size: 12px;
   color: white;
 }
</style>

這樣每次使用的時(shí)候

<template>
 <div class="music-list">
   <loading></loading>
 </div>
</template>
<script type="text/ecmascript-6">
 import Loading from 'base/loading/loading'
 export default {
   components: {
     Loading
   }
 }
</script>

2.是使用install注冊(cè)組件(Vue.use()來使用)

import './index.css'
 let Loading = {}
// 避免重復(fù)install撮躁,設(shè)立flag
Loading.installed = false
Loading.install = function (Vue) {
 if (Loading.installed) return
 Vue.prototype.$loading = {}
 Vue.prototype.$loading.show = () => {
 // 如果頁(yè)面有l(wèi)oading則不繼續(xù)執(zhí)行
 if (document.querySelector('#vue-loading')) return
 // 1、創(chuàng)建構(gòu)造器买雾,定義loading模板
 let LoadingTip = Vue.extend({
  template: `<div id="vue-loading">
     <div class="loader"></div>
     </div>`
 })
 // 2把曼、創(chuàng)建實(shí)例,掛載到文檔以后的地方
 let tpl = new LoadingTip().$mount().$el
 // 3漓穿、把創(chuàng)建的實(shí)例添加到body中
 document.body.appendChild(tpl)
 // 阻止遮罩滑動(dòng)
 document.querySelector('#vue-loading').addEventListener('touchmove', function (e) {
  e.stopPropagation()
  e.preventDefault()
 })
 Loading.installed = true
 }
 Vue.prototype.$loading.hide = () => {
 let tpl = document.querySelector('#vue-loading')
 document.body.removeChild(tpl)
 }
}
export default Loading 

將該組件導(dǎo)出嗤军,這里就存在一個(gè)關(guān)鍵點(diǎn):install, 只有使用install了晃危,我們?cè)趍ain.js中叙赚,才能夠直接use該組件,而install函數(shù)默認(rèn)自帶一個(gè)參數(shù)Vue僚饭,也就是我們正在使用的Vue對(duì)象纠俭,然后定義loading這一組件,使用$mount()給組件手動(dòng)掛載參數(shù)浪慌,然后將組件插入頁(yè)面中冤荆。

index.css

#vue-loading{
  width: 100%;
  height: 100%;
  position: absolute;
  left: 0;
  top: 0;
}
#vue-loading .loader{}
  position: absolute;
  width: 2.5em;
  height: 2.5em;
  top: calc(50% - 1.25em);
  left: calc(50% - 1.25em);
  transform: rotate(165deg);
}
#vue-loading .loader:before, #vue-loading .loader:after{
  content: '';
  position: absolute;
  top: 50%;
  left: 50%;
  display: block;
  width: 0.5em;
  height: 0.5em;
  border-radius: 0.25em;
  transform: translate(-50%, -50%);
}
#vue-loading .loader:before{
  animation: before 2s infinite;
}
#vue-loading .loader:after{
  animation: after 2s infinite;
}
.loading-context{
  position: absolute;
  width: 100%;
  top: calc(50% + 2.25em);
  text-align: center;
  height: 30px;
  line-height: 30px;
}
 
 
@keyframes before {
  0% {
    width: 0.5em;
    box-shadow: 1em -0.5em rgba(225, 20, 98, 0.75), -1em 0.5em rgba(111, 202, 220, 0.75);
  }
  35% {
    width: 2.5em;
    box-shadow: 0 -0.5em rgba(225, 20, 98, 0.75), 0 0.5em rgba(111, 202, 220, 0.75);
  }
  70% {
    width: 0.5em;
    box-shadow: -1em -0.5em rgba(225, 20, 98, 0.75), 1em 0.5em rgba(111, 202, 220, 0.75);
  }
  100% {
    box-shadow: 1em -0.5em rgba(225, 20, 98, 0.75), -1em 0.5em rgba(111, 202, 220, 0.75);
  }
}
 
@keyframes after {
  0% {
    height: 0.5em;
    box-shadow: 0.5em 1em rgba(61, 184, 143, 0.75), -0.5em -1em rgba(233, 169, 32, 0.75);
  }
  35% {
    height: 2.5em;
    box-shadow: 0.5em 0 rgba(61, 184, 143, 0.75), -0.5em 0 rgba(233, 169, 32, 0.75);
  }
  70% {
    height: 0.5em;
    box-shadow: 0.5em -1em rgba(61, 184, 143, 0.75), -0.5em 1em rgba(233, 169, 32, 0.75);
  }
  100% {
    box-shadow: 0.5em 1em rgba(61, 184, 143, 0.75), -0.5em -1em rgba(233, 169, 32, 0.75);
  }
}

使用:

// 在main.js中引入
import loading from "@/base/loading"

// 然后通過 USE方法全局注冊(cè)
Vue.use(Loading)

// 全局調(diào)用
this.$loading.show(options) 
this.$loading.hide(options)

但是這種方法,只能在vue實(shí)例存在的頁(yè)面中使用权纤,比如重新封裝ajax钓简,在ajax里添加loading乌妒,這個(gè)時(shí)候往往ajax都是封裝在單獨(dú)的js文件中,此時(shí)外邓,vue實(shí)例不存在撤蚊,就無法使用。故在上面的基礎(chǔ)上改進(jìn)如下版本:

import './index.css'
 let installed = false
// 避免重復(fù)install损话,設(shè)立flag
const loading =  {
 show(context = '') {
  if (installed) return
 // 如果頁(yè)面有l(wèi)oading則不繼續(xù)執(zhí)行
 if (document.querySelector('#vue-loading')) return
  // 1侦啸、創(chuàng)建構(gòu)造器,定義loading模板
  let divWrapper = document.createElement('div')
  divWrapper.setAttribute("id","vue-loading")
  let div = document.createElement('div')
  div.setAttribute('class','loader')
  let span = document.createElement('span')
  span.className = 'loading-context'
  span.innerHTML = context
  divWrapper.appendChild(div)
  divWrapper.appendChild(span)
  // 3丧枪、把創(chuàng)建的實(shí)例添加到body中
  document.body.appendChild(divWrapper)
  // 阻止遮罩滑動(dòng)
  document.querySelector('#vue-loading').addEventListener('touchmove', function (e) {
    e.stopPropagation()
    e.preventDefault()
  })
  installed = true
 },
 hide() {
  let tpl = document.querySelector('#vue-loading')
  if(!tpl) return
  document.body.removeChild(tpl)
 }
}
export default loading

index.css

#vue-loading{
  width: 100%;
  height: 100%;
  position: absolute;
  left: 0;
  top: 0;
}
#vue-loading .loader{}
  position: absolute;
  width: 2.5em;
  height: 2.5em;
  top: calc(50% - 1.25em);
  left: calc(50% - 1.25em);
  transform: rotate(165deg);
}
#vue-loading .loader:before, #vue-loading .loader:after{
  content: '';
  position: absolute;
  top: 50%;
  left: 50%;
  display: block;
  width: 0.5em;
  height: 0.5em;
  border-radius: 0.25em;
  transform: translate(-50%, -50%);
}
#vue-loading .loader:before{
  animation: before 2s infinite;
}
#vue-loading .loader:after{
  animation: after 2s infinite;
}
.loading-context{
  position: absolute;
  width: 100%;
  top: calc(50% + 2.25em);
  text-align: center;
  height: 30px;
  line-height: 30px;
}
 
 
@keyframes before {
  0% {
    width: 0.5em;
    box-shadow: 1em -0.5em rgba(225, 20, 98, 0.75), -1em 0.5em rgba(111, 202, 220, 0.75);
  }
  35% {
    width: 2.5em;
    box-shadow: 0 -0.5em rgba(225, 20, 98, 0.75), 0 0.5em rgba(111, 202, 220, 0.75);
  }
  70% {
    width: 0.5em;
    box-shadow: -1em -0.5em rgba(225, 20, 98, 0.75), 1em 0.5em rgba(111, 202, 220, 0.75);
  }
  100% {
    box-shadow: 1em -0.5em rgba(225, 20, 98, 0.75), -1em 0.5em rgba(111, 202, 220, 0.75);
  }
}
 
@keyframes after {
  0% {
    height: 0.5em;
    box-shadow: 0.5em 1em rgba(61, 184, 143, 0.75), -0.5em -1em rgba(233, 169, 32, 0.75);
  }
  35% {
    height: 2.5em;
    box-shadow: 0.5em 0 rgba(61, 184, 143, 0.75), -0.5em 0 rgba(233, 169, 32, 0.75);
  }
  70% {
    height: 0.5em;
    box-shadow: 0.5em -1em rgba(61, 184, 143, 0.75), -0.5em 1em rgba(233, 169, 32, 0.75);
  }
  100% {
    box-shadow: 0.5em 1em rgba(61, 184, 143, 0.75), -0.5em -1em rgba(233, 169, 32, 0.75);
  }
}

使用:

// 在使用的頁(yè)面中引入
import loading from "@/base/loading"

// 使用
loading.show()
loading.hide()

// 也可以在main.js將組將掛載到vue實(shí)例中

Vue.prototype.loading = loading

// 使用
this.$loading.show() 
this.$loading.hide() 

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末光涂,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子拧烦,更是在濱河造成了極大的恐慌忘闻,老刑警劉巖,帶你破解...
    沈念sama閱讀 219,539評(píng)論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件恋博,死亡現(xiàn)場(chǎng)離奇詭異齐佳,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)债沮,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,594評(píng)論 3 396
  • 文/潘曉璐 我一進(jìn)店門炼吴,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人疫衩,你說我怎么就攤上這事缺厉。” “怎么了隧土?”我有些...
    開封第一講書人閱讀 165,871評(píng)論 0 356
  • 文/不壞的土叔 我叫張陵提针,是天一觀的道長(zhǎng)。 經(jīng)常有香客問我曹傀,道長(zhǎng)辐脖,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,963評(píng)論 1 295
  • 正文 為了忘掉前任皆愉,我火速辦了婚禮嗜价,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘幕庐。我一直安慰自己久锥,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,984評(píng)論 6 393
  • 文/花漫 我一把揭開白布异剥。 她就那樣靜靜地躺著瑟由,像睡著了一般。 火紅的嫁衣襯著肌膚如雪冤寿。 梳的紋絲不亂的頭發(fā)上歹苦,一...
    開封第一講書人閱讀 51,763評(píng)論 1 307
  • 那天青伤,我揣著相機(jī)與錄音,去河邊找鬼殴瘦。 笑死狠角,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的蚪腋。 我是一名探鬼主播丰歌,決...
    沈念sama閱讀 40,468評(píng)論 3 420
  • 文/蒼蘭香墨 我猛地睜開眼,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼屉凯!你這毒婦竟也來了立帖?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,357評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤神得,失蹤者是張志新(化名)和其女友劉穎厘惦,沒想到半個(gè)月后偷仿,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體哩簿,經(jīng)...
    沈念sama閱讀 45,850評(píng)論 1 317
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,002評(píng)論 3 338
  • 正文 我和宋清朗相戀三年酝静,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了节榜。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 40,144評(píng)論 1 351
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡别智,死狀恐怖宗苍,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情薄榛,我是刑警寧澤讳窟,帶...
    沈念sama閱讀 35,823評(píng)論 5 346
  • 正文 年R本政府宣布,位于F島的核電站敞恋,受9級(jí)特大地震影響丽啡,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜硬猫,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,483評(píng)論 3 331
  • 文/蒙蒙 一补箍、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧啸蜜,春花似錦坑雅、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,026評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至蜂林,卻和暖如春蛹尝,著一層夾襖步出監(jiān)牢的瞬間后豫,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,150評(píng)論 1 272
  • 我被黑心中介騙來泰國(guó)打工突那, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留挫酿,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 48,415評(píng)論 3 373
  • 正文 我出身青樓愕难,卻偏偏與公主長(zhǎng)得像早龟,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子猫缭,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,092評(píng)論 2 355

推薦閱讀更多精彩內(nèi)容

  • 一:什么是閉包葱弟?閉包的用處? (1)閉包就是能夠讀取其他函數(shù)內(nèi)部變量的函數(shù)猜丹。在本質(zhì)上芝加,閉包就 是將函數(shù)內(nèi)部和函數(shù)外...
    xuguibin閱讀 9,622評(píng)論 1 52
  • ## 框架和庫(kù)的區(qū)別?> 框架(framework):一套完整的軟件設(shè)計(jì)架構(gòu)和**解決方案**。> > 庫(kù)(lib...
    Rui_bdad閱讀 2,911評(píng)論 1 4
  • Vue 實(shí)例 屬性和方法 每個(gè) Vue 實(shí)例都會(huì)代理其 data 對(duì)象里所有的屬性:var data = { a:...
    云之外閱讀 2,216評(píng)論 0 6
  • 獨(dú)臥榻前難安眠射窒,大雨滂沱帷幔濕藏杖。春風(fēng)不解蘭花意,玉蕭萬(wàn)里遞情思脉顿。
    婼離閱讀 277評(píng)論 0 4
  • 既然框架能跑起來蝌麸,接下來當(dāng)然是分析代碼。在My First Spring-Boot Project(1)提到需要添...
    Benson_Lim閱讀 155評(píng)論 0 0