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

vue3 自定義loading的操作方法

 更新時間:2023年11月06日 15:58:24   作者:唐十八_wei  
這篇文章主要介紹了vue3 自定義loading的操作方法,本文通過示例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友參考下吧

使用antdv 后發(fā)現(xiàn)只有button支持loaidng屬性,而其他元素不能使用loading來顯示是否加載中,需要套一層 a-spin 才能支持,非常不方便。

所以寫了個自定義的指令來進(jìn)行處理

新建loading.vue文件用來頁面顯示

<template>
  <div class="loading-container">
    <LoadingOutlined />
    <p>{{ state.loading.text }}</p>
  </div>
</template>
<script lang="ts" setup>
import { LoadingOutlined } from '@ant-design/icons-vue';
import { reactive } from 'vue';
const FONT_SIZE = {
  samll: {
    icon: '16px',
    p: '12px'
  },
  default: {
    icon: '20px',
    p: '16px'
  },
  large: {
    icon: '24px',
    p: '20px'
  }
}
const state = reactive({
  loading: {
    text: '正在加載中',
    fontSize: {
      icon: '20px',
      p: '16px'
    }
  } as { text?: string; fontSize?: { icon: string; p: string } }
})
function updateInfo(params: { text: string; size: 'samll' | 'default' | 'large' }) {
  state.loading = {
    text: params.text,
    fontSize: FONT_SIZE[params.size]
  }
}
defineExpose({ updateInfo })
</script>
<style lang="scss" scoped>
.loading-container {
  position: absolute;
  left: 0;
  top: 0;
  height: 100%;
  width: 100%;
  overflow: hidden;
  background: rgba($color: #ffffff, $alpha: 0.7);
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  font-size: 16px;
  color: #335dfd;
  z-index: 999999;
  :deep(.anticon-loading) {
    font-size: 20px;
  }
  p {
    margin-top: 10px;
    font-size: 16px;
  }
}
</style>

在新建個loading.ts 用來注冊v-loading 相關(guān)操作

import { createApp, Directive } from 'vue';
import Loading from './index.vue';
/**
 * @description 判斷是否為空對象
 * **/
export const isEmptyObj = (obj: object): boolean => {
  return JSON.stringify(obj) === "{}";
};
/** v-eLoading:[loadingConfig]="state.l||state.a */
const loading: Directive = {
  mounted(el, binding) {
    const app = createApp(Loading);
    const instance = app.mount(document.createElement('div')) as any;
    el.instance = instance;
    el.style.position = 'relative';
    const arg:any = binding.arg
    if (!isEmptyObj(arg as any)){
      const params = {
        text:arg?.text||'正在加載中',
        size:'default'
      }
      instance.updateInfo(params)
    }
      if (binding.value) {
        appendEl(el);
      }
  },
  updated(el, binding) {
    console.log(binding.value !== binding.oldValue)
    if (binding.value !== binding.oldValue) {
      binding.value ? appendEl(el) : removeEl(el);
    }
  },
};
const appendEl = (el: { appendChild: (arg0: any) => void; instance: { $el: any; }; }) => {
  el.appendChild(el.instance.$el);
};
const removeEl = (el: { removeChild: (arg0: any) => void; instance: { $el: any; }; }) => {
  el.removeChild(el.instance.$el);
};
export default loading;

最后在main.ts 進(jìn)行注冊

import loadingDirective from 'packages\Loading\index.ts'
createApp(App).directive('loading', loadingDirective).mount('#app')

在頁面中就可以直接進(jìn)行v-loading 進(jìn)行使用了

<div v-loading="true"></div>

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

相關(guān)文章

  • Vue+element+cookie記住密碼功能的簡單實現(xiàn)方法

    Vue+element+cookie記住密碼功能的簡單實現(xiàn)方法

    這篇文章主要給大家介紹了Vue+element+cookie記住密碼功能的簡單實現(xiàn)方法,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-09-09
  • vue項目中一定會用到的性能優(yōu)化技巧

    vue項目中一定會用到的性能優(yōu)化技巧

    這篇文章主要為大家介紹了vue項目中一定會用到的性能優(yōu)化技巧實例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-07-07
  • 詳解Axios統(tǒng)一錯誤處理與后置

    詳解Axios統(tǒng)一錯誤處理與后置

    這篇文章主要介紹了詳解Axios統(tǒng)一錯誤處理與后置,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-09-09
  • vue高德地圖繪制行政區(qū)邊界功能

    vue高德地圖繪制行政區(qū)邊界功能

    這篇文章主要介紹了vue高德地圖繪制行政區(qū)邊界功能,本文通過實例代碼給大家介紹的非常詳細(xì),感興趣的朋友一起看看吧
    2024-03-03
  • 解決vue中使用proxy配置不同端口和ip接口問題

    解決vue中使用proxy配置不同端口和ip接口問題

    這篇文章主要介紹了解決vue中使用proxy配置不同端口和ip接口問題 ,本文給大家介紹的非常詳細(xì),具有一定的參考借鑒價值,需要的朋友可以參考下
    2019-08-08
  • element中TimePicker時間選擇器禁用部分時間(顯示禁用到分鐘)

    element中TimePicker時間選擇器禁用部分時間(顯示禁用到分鐘)

    這篇文章主要介紹了element中TimePicker時間選擇器禁用部分時間(顯示禁用到分鐘),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-03-03
  • Vue3?中的??shallowReactive?詳解

    Vue3?中的??shallowReactive?詳解

    本文深入探討了Vue3中新特性shallowReactive的使用和原理,shallowReactive是創(chuàng)建淺響應(yīng)式對象的API,只對對象的第一層屬性進(jìn)行響應(yīng)式轉(zhuǎn)換,不對嵌套對象處理,有助于性能優(yōu)化和狀態(tài)管理,同時也指出了shallowReactive在使用中的注意事項
    2024-10-10
  • 基于vue2的table分頁組件實現(xiàn)方法

    基于vue2的table分頁組件實現(xiàn)方法

    這篇文章主要為大家詳細(xì)介紹了基于vue2的table分頁組件實現(xiàn)方法,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-03-03
  • vue的el-select綁定的值無法選中el-option問題及解決

    vue的el-select綁定的值無法選中el-option問題及解決

    這篇文章主要介紹了vue的el-select綁定的值無法選中el-option問題及解決,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-09-09
  • vue中的過濾器實例代碼詳解

    vue中的過濾器實例代碼詳解

    這篇文章主要介紹了vue中的過濾器,本文通過文字實例代碼相結(jié)合的形式給大家介紹的非常詳細(xì),具有一定的參考借鑒價值,需要的朋友可以參考下
    2019-06-06

最新評論