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

VUE-ElementUI 自定義Loading圖操作

 更新時間:2020年11月11日 11:19:13   作者:清水迎朝陽  
這篇文章主要介紹了VUE-ElementUI 自定義Loading圖操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧

需求:

element ui loading圖只能使用自己的loading圖,

但很多場景下,需要替換成自己的gif圖

雖然文檔中有些, element-loading-spinner="el-icon-loading" 可指定自定義圖

但經測試,也只是只能再elementui 圖標庫中的圖, 不是我們想的那個自定義圖類的意思。

自定義圖方法:

1) 添加自定義elementUI loading樣式

asserts下 新建CSS文件夾 及CSS文件比如myCss.css

再里面,寫入自定義的element類CSS樣式

.el-loading-spinner{
  /*這個是自己想設置的 gif 加載動圖*/
  background-image:url('../img/loading.gif');
  background-repeat: no-repeat;
  background-size: 200px 120px;
  height:100px;
  width:100%;
  background-position:center;
  /*覆蓋 element-ui 默認的 50% 因為此處設置了height:100%,所以不設置的話,會只顯示一半,因為被top頂下去了*/
  top:40%;
 }
.el-loading-spinner .circular {
 /*隱藏 之前 element-ui 默認的 loading 動畫*/
 
 display: none; 
} 
.el-loading-spinner .el-loading-text{
 /*為了使得文字在loading圖下面*/
 margin:85px 0px; 
}

CSS 細調,需要在瀏覽器調試工具中細調

2)main.js 導入自定義樣式

這里注意,要在導入elementUI之后,再導入自己的樣式,要不然會被elementUI覆蓋

import ElementUI from 'element-ui';
import 'element-ui/lib/theme-chalk/index.css';
Vue.use(ElementUI); //element 
 
//自定義的element UI loading樣式
import './assets/css/myCss.css'

3) v-loading

 <el-container
   v-loading="loading"
   element-loading-background="rgba(255, 255,255, 0.5)"
   element-loading-text="加載中..." 
 >

注意,這里 不要加上element-loading-spinner="el-icon-loading" ,否則 也會同時出現element圖庫中對應的loading圖

4)對應加載邏輯

 data () {
 return { 
  loading: true 
 }
 }, 
 startLoading()
 { 
  this.loading=true; 
 },
 
 endLoading(){
   this.loading=false;
  },

axios請求接口時,開始loading,收到數據后,loading結束

  Ajx_GetClassList()
  {
   this.startLoading(); 
    this.$axios(
    {
     url: url,
     method:'POST',
    }
   ).then(res=>{
 
     this.endLoading();
 
    }) 
  },

5) 運行時,是正常顯示,但編譯后,看不到自定義的圖片資源了

原因,VUE項目打包后,樣式目錄結構變?yōu)閟tatic/css

解決

build->utils.js 配置文件添加

publicPath: '../../'

 // Extract CSS when that option is specified
 // (which is the case during production build)
 if (options.extract) {
  return ExtractTextPlugin.extract({
  use: loaders,
  publicPath:'../../', // 解決element-ui中組件圖標不顯示問題
  fallback: 'vue-style-loader'
  })

這樣,編譯后的element-ui資源也可以正常訪問了

自定義loading圖效果

補充知識:vue+elementUI自定義通用table組件

自定義通用table組件,帶分頁,后端排序,路由帶參數跳轉,多選框,字段格式化

1.tableList組件

<!-- 費用報銷編輯彈框 -->
<template>
  <div class="table-temp">
    <el-table
      :data="tableData"
      border
      size="mini"
      fit
      highlight-current-row
      height="500"
      v-loading="loading"
      @selection-change="handleSelectionChange"
      @sort-change="sortChange"
    >
      <el-table-column type="selection" width="55" align="center"></el-table-column>
      <el-table-column type="index" label="序號" align="center" fixed></el-table-column>
      <!-- prop: 字段名name, label: 展示的名稱, fixed: 是否需要固定(left, right), minWidth: 設置列的最小寬度(不傳默認值), active: 是否有操作列
      active.name: 操作列字段名稱, active.clickFun: 操作列點擊事件, formatData: 格式化內容-->
      <el-table-column
        v-for="(item, key) in tableHeader"
        :key="key"
        :prop="item.prop"
        :label="item.label"
        :fixed="item.fixed"
        :min-widitem="item.minWidth"
        align="center"
        :sortable="item.sortable"
      >
        <template slot-scope="scope">
          <div v-if="item.active">
            <el-button
              v-for="(o, key) in item.active"
              :key="key"
              @click="handleActive(scope.row, o.router, o.routerId)"
              type="text"
              size="small"
            >{{o.name}}</el-button>
          </div>
          <div v-else>
            <a class="btn-a"
              v-if="item.router"
              @click="handleActive(scope.row,item.router, item.routerId)"
            >
              <span v-if="!item.formatData">{{ scope.row[item.prop] }}</span>
              <span v-else>{{ scope.row[item.prop] | formatters(item.formatData) }}</span>
            </a>
            <div v-else>
              <span v-if="!item.formatData">{{ scope.row[item.prop] }}</span>
              <span v-else>{{ scope.row[item.prop] | formatters(item.formatData) }}</span>
            </div>
          </div>
        </template>
      </el-table-column>
    </el-table>
    <div class="pagination">
      <el-pagination
        background
        layout="total, prev, pager, next"
        :current-page="pagination.pageIndex"
        :page-size="pagination.pageSize"
        :total="pagination.pageTotal"
        @current-change="handlePageChange"
      ></el-pagination>
    </div>
  </div>
</template>
<script>
var _ = require('lodash');
export default {
  props: {
    tableData: {
      type: Array,
      default: function() {
        return [];
      }
    },
    tableHeader: {
      type: Array,
      default: function() {
        return [];
      }
    },
    loading: {
      type: Boolean,
      default: false
    },
    pagination: {
      type: Object,
      default: {
        pageIndex: 0,
        pageSize: 15,
        pageTotal: 0
      }
    }
  },
  data() {
    return {
      multipleSelection: [],
      newPagination: {
        pageIndex: 0,
        pageSize: 15,
        pageTotal: 0
      }
    };
  },
  methods: {
    // 多選操作
    handleSelectionChange(val) {
      this.multipleSelection = val;
      this.$emit('selectFun', { backData: this.multipleSelection });
    },
    // 分頁導航
    handlePageChange(val) {
      console.log('handlePageChange:', val);
      this.$set(this.pagination, 'pageIndex', val);
      //調用父組件方法
      this.$emit('pageChange', { backData: this.pagination});
    },
    // row:本行數據,route:要跳轉的路由路徑,跳轉要傳的參數routeId
    handleActive(row, route, routeId) {
      console.log(row);
      this.$router.push({
        path: '/' + route,
        query: {
          id: row[routeId]
        }
      });
    },
    //后端排序
    sortChange(column) {
      //console.log('sortChange:', column);
      //調用父組件方法
      this.$emit('sortChange', { backData: column });
    }
  },
  watch: {
    
    }
  },
  computed: {
  },
  created() {
  }
};
</script>
<style scoped>
.btn-a{
  color: #409EFF
}
</style>

2.組件使用

<template>
  <div>
<!-- 表格 -->
      <table-List
        :tableData="tableData"
        :tableHeader="tableHeader"
        :loading="loading"
        :pagination="pagination"
        @pageChange="pageChange"
        @selectFun="selectFun"
        @sortChange="sortChange"
      ></table-List>
  </div>
</template>
<script>
import appMain from '../../../utils/app_main';
export default {
  data() {
    return {
//    請求加載
      loading: false,
      // 分頁信息
      pagination: {
        pageIndex: 1,
        pageSize: 10,
        pageTotal: 60
      },
      tableHeader: [
        // 表頭數據
        { prop: 'id', label: '離職編號', minWidth: '100px', router: 'quitDetail', routerId: 'id', sortable: 'custom' },
        {
          prop: 'resignationUserName',
          label: '姓名',
          router: 'employeeDetail',
          routerId: 'resignationUserId',
          sortable: 'custom'
        },
        { prop: 'departName', label: '部門', minWidth: '100px', sortable: 'custom' },
        { prop: 'jobRole', label: '所在崗位', sortable: 'custom' },
        {
          prop: 'onbordingTime',
          label: '入職日期',
          formatData: function(val) {
            let date = new Date(val);
            return appMain.formatDate(date, 'yyyy-MM-dd');
          },
          sortable: 'custom'
        },
        {
          prop: 'resignationTime',
          label: '離職日期',
          formatData: function(val) {
            let date = new Date(val);
            return appMain.formatDate(date, 'yyyy-MM-dd');
          },
          minWidth: '100px',
          sortable: 'custom'
        },
        { prop: 'resignationReason', label: '離職原因', minWidth: '100px', sortable: 'custom' },
        { prop: 'status', label: '流程狀態(tài)', minWidth: '100px', sortable: 'custom' }
      ],
      tableData: [],
      multipleSelection: [],
    };
  },
 
  methods: {
    // 組件選擇完后把數據傳過來
    selectFun(data) {
      this.multipleSelection = data.backData;
    },
    //表格組件返回排序對象
    sortChange(data) {
      let column = data.backData;
      //排序
      if (column.order) {
        //倒序
        if (column.order === 'descending') {
          // this.query.sortColumn = column.prop + ' ' + 'desc';
        } else {
          // this.query.sortColumn = column.prop;
        }
      } else {
        //不排序
        // this.query.sortColumn = '';
      }
      //請求接口
    },
   
    //分頁導航
    pageChange(data) {
      this.pagination = data.backData;
      console.log('pageChange:', this.pagination);
      //分頁變化--請求接口
    },  
  }
};
</script>

3.appMain.js

 class appMain {
 
  }
// 時間格式化
  formatDate(date, fmt) {
    var date = new Date(date)
    if (/(y+)/.test(fmt)) {
      fmt = fmt.replace(RegExp.$1, (date.getFullYear() + '').substr(4 - RegExp.$1.length));
    }
    let o = {
      'M+': date.getMonth() + 1,
      'd+': date.getDate(),
      'h+': date.getHours(),
      'm+': date.getMinutes(),
      's+': date.getSeconds()
    };
    for (let k in o) {
      if (new RegExp(`(${k})`).test(fmt)) {
        let str = o[k] + '';
        fmt = fmt.replace(RegExp.$1, (RegExp.$1.length === 1) ? str : this.padLeftZero(str));
      }
    }
    return fmt;
  };
  padLeftZero(str) {
    return ('00' + str).substr(str.length);
  }
export default new appMain()

以上這篇VUE-ElementUI 自定義Loading圖操作就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關文章

  • vue+node+webpack環(huán)境搭建教程

    vue+node+webpack環(huán)境搭建教程

    這篇文章主要為大家詳細介紹了vue+node+webpack環(huán)境搭建教程,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-11-11
  • vue3如何使用watch監(jiān)聽props中的數據

    vue3如何使用watch監(jiān)聽props中的數據

    在vue項目中,父子組件數據傳遞是最常見的場景,但是今天在開發(fā)過程中父級數據傳遞到子組件,控制子組件的顯隱,下面這篇文章主要給大家介紹了關于vue3如何使用watch監(jiān)聽props中數據的相關資料,需要的朋友可以參考下
    2022-10-10
  • vue3編譯報錯ESLint:defineProps is not defined no-undef的問題

    vue3編譯報錯ESLint:defineProps is not defined&nbs

    這篇文章主要介紹了vue3編譯報錯ESLint:defineProps is not defined no-undef的問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-03-03
  • Vue性能優(yōu)化的方法

    Vue性能優(yōu)化的方法

    這篇文章主要介紹了Vue性能優(yōu)化的方法,文中講解非常細致,幫助大家更好的理解和學習vue,感興趣的朋友可以了解下
    2020-07-07
  • vue3利用customRef實現防抖

    vue3利用customRef實現防抖

    防抖就是對于頻繁觸發(fā)的事件添加一個延時同時設定一個最小觸發(fā)間隔,防抖大家都學過,但是如何在?Vue3?里中將防抖做到極致呢,下面小編就來和大家詳細講講
    2023-10-10
  • vue.js todolist實現代碼

    vue.js todolist實現代碼

    這篇文章主要介紹了vue.js todolist實現代碼,需要的朋友可以參考下
    2017-10-10
  • 關于vue.js中實現方法內某些代碼延時執(zhí)行

    關于vue.js中實現方法內某些代碼延時執(zhí)行

    今天小編就為大家分享一篇關于vue.js中實現方法內某些代碼延時執(zhí)行,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-11-11
  • Vue加載中動畫組件使用方法詳解

    Vue加載中動畫組件使用方法詳解

    這篇文章主要為大家詳細介紹了Vue加載中動畫組件使用方法,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-03-03
  • Vue?cli3?chainWepack使用方法示例詳解

    Vue?cli3?chainWepack使用方法示例詳解

    這篇文章主要為大家介紹了Vue?cli3?chainWepack使用方法示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-11-11
  • Vuex中mutations和actions的區(qū)別及說明

    Vuex中mutations和actions的區(qū)別及說明

    這篇文章主要介紹了Vuex中mutations和actions的區(qū)別及說明,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-12-12

最新評論