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

vue自定義加載指令最新詳解

 更新時間:2022年06月07日 16:53:26   作者:水開泡茶  
這篇文章主要介紹了vue自定義加載指令的相關(guān)知識,主要包括創(chuàng)建加載組件,創(chuàng)建指令的方法,結(jié)合實例代碼給大家介紹的非常詳細,需要的朋友可以參考下

前言

用過element-ui的都應(yīng)該知道,里面有一個loading組件,有兩種調(diào)用方法:指令和服務(wù)。但是只有一種加載效果,為了豐富加載效果和方便使用,于是寫了一個自定義loading指令。

創(chuàng)建加載組件

首先,需要創(chuàng)建loading組件,展示需要的加載效果,因人而異,不再贅述。

創(chuàng)建指令

指令文件

首先,創(chuàng)建一個js文件用于書寫自定義指令,在這個文件中導(dǎo)入Vueloading組件:

import Vue from 'vue'
import loading from './loading.vue'

創(chuàng)建構(gòu)造器

主要是使用Vue.extend構(gòu)造器,可以簡單的理解為傳入一個組件作為參數(shù),然后返回該組件的類,可以使用這個類new出實例。

// loading組件作為參數(shù)傳入
const loadingConstructor = Vue.extend(loading)

書寫指令

在此之前,設(shè)定好指令的參數(shù),在本人的項目中,參數(shù)有兩種方式:1.傳入一個布爾值,代表是否開啟加載;2.傳入一個對象,對象中包含是否開啟遮罩、提示文字、加載背景顏色等屬性,方便開發(fā)時,高度自定義laoding。
指令的觸發(fā)主要是在update中,該屬性可接收一個函數(shù),每次指令的參數(shù)改變時都會觸發(fā)該函數(shù),就是在這里判斷開啟或者關(guān)閉加載效果。 整體代碼如下,附有詳細注釋:

const loadingDirective = Vue => {
  Vue.directive('custLoading', {
    /**
     * binding:
     * 1.可傳單個參數(shù),為布爾值;
     * 2.也可用json傳多個參數(shù){ loading, tip, background }
     *  2.1 loading { boolean } 是否開啟遮罩
     *  2.2 tip { string } 提示文字
     *  2.3 background { string } 加載背景顏色
     * */
    // update: 參數(shù)變化時觸發(fā)
    update: function (el, binding, vnode) {
      const value = binding.value
      let backup = {}
      // 判斷參數(shù)類型,將參數(shù)都轉(zhuǎn)換為對象,方便后續(xù)統(tǒng)一處理
      typeof value === 'boolean' ? (backup.loading = value) : (backup = value || {})
      // 取出所有的參數(shù)
      const { loading, tip, background } = backup
      // 根據(jù)loading參數(shù)判斷開啟或者關(guān)閉加載效果,開啟和關(guān)閉函數(shù)后續(xù)會講到
      loading ? createLoading(el, tip, background) : close(el?.customLoadingInstance?.$el)
    },
    // unbid: 指令卸載時觸發(fā)
    unbind: function (el, binding) {
      const { loading } = binding.value || {}
      // 如果還在展示加載特效,則關(guān)閉
      loading && close(el?.customLoadingInstance?.$el)
    }
  })
}
export default loadingDirective

開啟函數(shù)

在上面的指令中,當(dāng)開啟的參數(shù)為true時,回會調(diào)用一個createLoading函數(shù)用于將加載效果加入到指令掛載的元素上,具體思路如下:
1.在調(diào)用時,我們傳入了三個參數(shù)給它,分別是掛載有自定義加載指令的元素、加載時的提示、加載背景顏色,詳細可見上面的指令代碼。
2.在執(zhí)行之前,還需要進行判斷當(dāng)前的Vue實例是否運行在服務(wù)器上,如果是,此時不需要將加載效果展示出來;或者該元素之前是否已經(jīng)帶有加載特效,如果是的話,沒必要在開啟一次,不然到時會出現(xiàn)多層加載效果,既多余,又讓頁面顯得混亂。
3.判斷需要使用加載效果的元素是否還存在,不存在,則掛載到#main或者document.body上。
4.判斷元素上是否存在定位或者其他條件,在本人的項目中,使用絕對定位來使加載效果鋪滿元素,因此需要進行判斷,如果沒有定位,則加上relative。
5.使用loadingConstructor,創(chuàng)建loading實例,將實例作為子元素通過appendChild,放進需要展示的元素中,就可以展示出來;同時,在展示的元素上增加一個屬性customLoadingInstance,用于記錄當(dāng)前的loading實例,方便后續(xù)的銷毀。
整體代碼如下:

const createLoading = (target, tip= '加載中,請稍候...', background) => {
  // 判斷是否允許開啟加載特效
  if (Vue.prototype.$isServer || target?.customLoadingInstance) return
  const mainEL = document.querySelector('#main')
  // 判斷展示加載效果的元素是否存在
  const parentNode = target || mainEL || document.body
  // 判斷父級是否存在定位,沒有則添加定位
  const position = getComputedStyle(parentNode)?.position
  (!position || position === 'static') && (parentNode.style.position = 'relative')
  // 創(chuàng)建loading實例
  const instance = new loadingConstructor({
    el: document.createElement('div'),
    data: { background, tip, parentNodeWidth: parentNode.clientWidth, isShow: true }
  })
  // 注意:loading實例是一個Vue組件對象,真正的DOM放在實例的$el屬性上
  parentNode.appendChild(instance.$el)
  parentNode.customLoadingInstance = instance
  
  return instance
}

關(guān)閉函數(shù)

有開啟就得有結(jié)束,當(dāng)開啟的參數(shù)為false時,關(guān)閉加載效果。該函數(shù)接收loading實例的$el,其實就是加載效果的DOM元素,思路如下:
1.為了使加載組件看起來是逐漸消失的,不得在第一時間將加載效果的DOM元素刪除,而是給它添加一個逐漸消失的動畫,通過一個class設(shè)定。
2.設(shè)定動畫消失時間,由loading組件內(nèi)部實現(xiàn)在規(guī)定時間內(nèi),將整個加載效果執(zhí)行完成或者淡出頁面。也可省略此步驟,直接就將其移除。 之所以加入這個效果,是為了用戶視覺上感受更好。
3.創(chuàng)建定時器,用于在加載效果消失時,刪除加載效果的DOM元素。同2,也可直接移除。

const close = (target) => {
  if (!target) return
  // 添加逐漸消失的class
  target.className += ' custom-loading-disappear'
  // 獲取loading實例
  const instance = target?.parentNode?.customLoadingInstance
  //  設(shè)定消失時間。
  instance?.$data?.dur && (instance.$data.dur = 0.8)
  // 設(shè)定定時器,用于在加載效果消失時,刪除加載效果的`DOM`元素。
  let timer = setTimeout(() => {
    if (target && target.parentNode) {
      // 將customLoadingInstance 屬性置為null,才不會干擾下一次開啟
      target.parentNode.customLoadingInstance = null
      // 將加載效果的DOM元素移除
      target.parentNode.removeChild(target)
    }
    clearTimeout(timer)
    timer = null
  }, 1100)
}

到此這篇關(guān)于vue自定義加載指令的文章就介紹到這了,更多相關(guān)vue自定義加載指令內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • vue-awesome-swiper 基于vue實現(xiàn)h5滑動翻頁效果【推薦】

    vue-awesome-swiper 基于vue實現(xiàn)h5滑動翻頁效果【推薦】

    說到h5的翻頁,很定第一時間想到的是swiper。但是我當(dāng)時想到的卻是,vue里邊怎么用swiper。這篇文章主要介紹了vue-awesome-swiper - 基于vue實現(xiàn)h5滑動翻頁效果 ,需要的朋友可以參考下
    2018-11-11
  • vue在頁面中如何使用window全局變量

    vue在頁面中如何使用window全局變量

    這篇文章主要介紹了vue在頁面中如何使用window全局變量問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-05-05
  • vue生成token并保存到本地存儲中

    vue生成token并保存到本地存儲中

    這篇文章主要介紹了vue生成token并保存到本地存儲中,本文給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友可以參考下
    2018-07-07
  • vue省市區(qū)三聯(lián)動下拉選擇組件的實現(xiàn)

    vue省市區(qū)三聯(lián)動下拉選擇組件的實現(xiàn)

    本篇文章主要介紹了vue省市區(qū)三聯(lián)動下拉選擇組件的相關(guān)知識。具有很好的參考價值。下面跟著小編一起來看下吧
    2017-04-04
  • vue中路由傳參6種方式總結(jié)

    vue中路由傳參6種方式總結(jié)

    這篇文章主要為大家詳細介紹了vue中路由傳參6種方式,文中的示例代碼講解詳細,具有一定的學(xué)習(xí)價值,感興趣的小伙伴可以跟隨小編一起了解一下
    2023-08-08
  • vue如何引入sass全局變量

    vue如何引入sass全局變量

    sass或者less都提供變量設(shè)置,在需求切換主題的項目中使用less或者sass變量,這篇文章主要介紹了vue引入sass全局變量,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-06-06
  • vue使用jsonp抓取qq音樂數(shù)據(jù)的方法

    vue使用jsonp抓取qq音樂數(shù)據(jù)的方法

    這篇文章主要介紹了vue使用jsonp抓取qq音樂數(shù)據(jù)的方法,非常不錯,具有一定的參考借鑒價值,需要的朋友可以參考下
    2018-06-06
  • 詳解vue中v-for和v-if一起使用的替代方法template

    詳解vue中v-for和v-if一起使用的替代方法template

    這篇文章主要介紹了vue中v-for和v-if一起使用的替代方法template,使用的版本是vue?2.9.6和element-ui:?2.15.6,通過實例代碼給大家講解的非常詳細,需要的朋友可以參考下
    2022-05-05
  • 前端大文件上傳與下載(分片上傳)的詳細過程

    前端大文件上傳與下載(分片上傳)的詳細過程

    最近遇見一個需要上傳超大大文件的需求,所以下面這篇文章主要給大家介紹了關(guān)于前端大文件上傳與下載(分片上傳)的詳細過程,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下
    2022-11-11
  • vue?+?ele?實現(xiàn)下拉選擇框和下拉多選選擇框處理方案

    vue?+?ele?實現(xiàn)下拉選擇框和下拉多選選擇框處理方案

    這篇文章主要介紹了vue?+?ele?實現(xiàn)下拉選擇框和下拉多選選擇框處理方案,本文通過實例代碼給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2023-08-08

最新評論