283c9ff2a66da5caf4df02fb815b5782.json 32 KB

1
  1. {"remainingRequest":"/usr/local/develop/php/www/waibao/project/NN2020060801/addons/admin/node_modules/vue-loader/lib/index.js??vue-loader-options!/usr/local/develop/php/www/waibao/project/NN2020060801/addons/admin/src/components/EleDataTable/index.vue?vue&type=script&lang=js&","dependencies":[{"path":"/usr/local/develop/php/www/waibao/project/NN2020060801/addons/admin/src/components/EleDataTable/index.vue","mtime":1616566600000},{"path":"/usr/local/develop/php/www/waibao/project/NN2020060801/addons/admin/node_modules/cache-loader/dist/cjs.js","mtime":499162500000},{"path":"/usr/local/develop/php/www/waibao/project/NN2020060801/addons/admin/node_modules/babel-loader/lib/index.js","mtime":499162500000},{"path":"/usr/local/develop/php/www/waibao/project/NN2020060801/addons/admin/node_modules/cache-loader/dist/cjs.js","mtime":499162500000},{"path":"/usr/local/develop/php/www/waibao/project/NN2020060801/addons/admin/node_modules/vue-loader/lib/index.js","mtime":499162500000}],"contextDependencies":[],"result":[{"type":"Buffer","data":"base64://
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//

export default {
  name: "EleDataTable",
  props: {
    config: {  // 数据表格参数配置
      type: Object,
      default() {
        return {}
      }
    },
    data: Array,  // 前端分页直接指定数据
    choose: Array,  // 列表选中数据(多选)
    current: Object,  // 列表选中数据(单选)
    servePage: Boolean,  // 强制后端分页
    // 表格参数
    size: String,
    width: [String, Number],
    height: [String, Number],
    maxHeight: [String, Number],
    fit: {
      type: Boolean,
      default: true
    },
    stripe: Boolean,
    border: {
      type: Boolean,
      default: true
    },
    rowKey: [String, Function],
    showHeader: {
      type: Boolean,
      default: true
    },
    showSummary: Boolean,
    sumText: String,
    summaryMethod: Function,
    rowClassName: [String, Function],
    rowStyle: [Object, Function],
    cellClassName: [String, Function],
    cellStyle: [Object, Function],
    headerRowClassName: [String, Function],
    headerRowStyle: [Object, Function],
    headerCellClassName: [String, Function],
    headerCellStyle: [Object, Function],
    highlightCurrentRow: Boolean,
    currentRowKey: [String, Number],
    emptyText: String,
    expandRowKeys: Array,
    defaultExpandAll: Boolean,
    defaultSort: Object,
    tooltipEffect: String,
    spanMethod: Function,
    selectOnIndeterminate: {
      type: Boolean,
      default: true
    },
    indent: {
      type: Number,
      default: 16
    },
    treeProps: {
      type: Object,
      default() {
        return {
          hasChildren: 'hasChildren',
          children: 'children'
        };
      }
    },
    lazy: Boolean,
    load: Function,
    // 分页组件参数
    pagerCount: {
      type: Number,
      default: 5
    },
    layout: {
      default: 'total, sizes, prev, pager, next, jumper'
    },
    pageSizes: Array,
    prevText: String,
    nextText: String,
    hideOnSinglePage: Boolean
  },
  data() {
    // 分页参数
    let page = false;
    if (this.config.page !== false) {
      page = Object.assign({page: 1, limit: 10}, this.config.page === true ? {} : this.config.page);
    }
    // 请求参数名
    let request = Object.assign({
      pageName: 'page', limitName: 'limit', sortName: 'sort', orderName: 'order'
    }, this.config.request);
    return {
      loading: false,  // 加载状态
      mData: [],  // 列表数据源(后端)
      count: this.data ? this.data.length : 0,  // 总数量
      page: page,  // 分页参数
      order: this.config.order ? this.config.order : {},  // 排序参数
      request: request  // 请求参数名
    };
  },
  computed: {
    /* 表格当前显示数据 */
    list() {
      let allData;
      if (this.data) {
        allData = this.data;
      } else if (this.mData.length < this.count) {
        return this.mData;
      } else {
        allData = this.mData;
      }
      let sort = this.order[this.request.sortName],
          order = this.order[this.request.orderName];
      if (this.page) {  // 进行前端分页、排序
        let start = (this.page.page - 1) * this.page.limit;
        let end = start + this.page.limit;
        end = end > allData.length ? allData.length : end;
        if (sort) {
          return allData.sort((a, b) => {
            if (b[sort] == a[sort]) return 0;
            if (order === 'desc') {
              return (a[sort] < b[sort]) ? 1 : -1;
            } else {
              return (a[sort] < b[sort]) ? -1 : 1;
            }
          }).slice(start, end);
        } else {
          return allData.slice(start, end);
        }
      } else {  // 进行前端排序
        if (sort) {
          return allData.sort((a, b) => {
            if (b[sort] == a[sort]) return 0;
            if (order === 'desc') {
              return (a[sort] < b[sort]) ? 1 : -1;
            } else {
              return (a[sort] < b[sort]) ? -1 : 1;
            }
          });
        } else {
          return allData;
        }
      }
    },
    /* 表格索引开始序号 */
    tableIndex() {
      if (!this.page) return 1;
      return (this.page.page - 1) * this.page.limit + 1;
    }
  },
  watch: {
    /* 监听数据改变 */
    data() {
      this.count = this.data.length;
      if (this.page) {
        let maxPage = Math.ceil(this.count / this.page.limit);
        if (maxPage < this.page.page) this.page.page = maxPage || 1;
      }
    }
  },
  mounted() {
    this.reload(true);
  },
  methods: {
    /* 获取数据 */
    reload(first) {
      let config;
      if (typeof first === 'object') {
        config = Object.assign({}, this.config, first);
        first = false;
      } else {
        config = this.config;
      }
      if (!first) {
        // 分页参数
        if (config.page) {
          this.page = Object.assign({
            page: 1, limit: 10
          }, this.page || {}, config.page === true ? {} : config.page);
        } else if (this.page === false) {
          this.page = false;
        }
        // 排序参数
        if (config.order) Object.assign(this.order, config.order);
        // 请求参数名
        if (config.request) Object.assign(this.request, config.request);
      }
      if (config.url && (this.servePage || !first || !this.mData.length || this.mData.length < this.count)) {  // 后端分页
        this.loading = true;
        let pageParam = {};
        if (this.page) {
          pageParam[this.request.pageName] = this.page.page;
          pageParam[this.request.limitName] = this.page.limit;
        }
        let params, data = Object.assign({}, config.where || {}, pageParam, this.order);
        if (config.parseParam) data = config.parseParam(data);
        let method = config.method ? config.method.toUpperCase() : 'GET';
        if (['POST', 'PUT', 'PATCH'].indexOf(method) === -1) {
          params = data;
          data = undefined;
        } else if (config.contentType && config.contentType.toLowerCase().indexOf('form') !== -1) {
          let formData = new FormData();
          for (let key in data) {
            if (!Object.prototype.hasOwnProperty.call(data, key)) continue;
            formData.append(key, data[key]);
          }
          data = formData;
        }
        this.$http.request({
          url: config.url, method: method,
          params: params, data: data, headers: config.headers
        }).then(res => {
          this.loading = false;
          if (config.parseData) res.data = config.parseData(res.data);
          if (res.data.code === 0) {
            this.mData = res.data.data;
            this.count = res.data.count || this.mData.length;
            if (this.page) {
              let maxPage = Math.ceil(this.count / this.page.limit);
              if (maxPage < this.page.page) this.page.page = maxPage || 1;
            }
            this.$emit('done', res.data, this.page ? this.page.page : 1, this.count, this.$refs.dataTable);
          } else {
            this.$message.error(res.data.msg || '获取数据失败, 正确的状态码为0');
          }
        }).catch(e => {
          this.loading = false;
          this.$message.error(e.message);
        });
      } else {  // 前端分页
        this.$emit('done', {data: this.list}, this.page ? this.page.page : 1, this.count, this.$refs.dataTable);
      }
    },
    /* 获取列表当前显示数据 */
    getData() {
      return this.list;
    },
    /* 获取列表的排序参数 */
    getOrder() {
      return this.order;
    },
    /* 获取列表的分页参数 */
    getPage() {
      return this.page;
    },
    /* 分页limit改变 */
    pageSizeChange(limit) {
      this.page.limit = limit;
      this.reload(true);
    },
    /* 分页page改变 */
    pageCurrentChange(page) {
      this.page.page = page;
      this.reload(true);
    },
    select(selection, row) {
      this.$emit('select', selection, row);
    },
    selectAll(selection) {
      this.$emit('select-all', selection);
    },
    /* 多选改变 */
    selectionChange(selection) {
      this.$emit('update:choose', selection);
      this.$emit('selection-change', selection);
    },
    cellMouseEnter(row, column, cell, event) {
      this.$emit('cell-mouse-enter', row, column, cell, event);
    },
    cellMouseLeave(row, column, cell, event) {
      this.$emit('cell-mouse-leave', row, column, cell, event);
    },
    cellClick(row, column, cell, event) {
      this.$emit('cell-click', row, column, cell, event);
    },
    cellDblclick(row, column, cell, event) {
      this.$emit('cell-dblclick', row, column, cell, event);
    },
    /* 行点击事件 */
    rowClick(row, column, event) {
      if (this.highlightCurrentRow) {
        if (this.choose.length === 0 || this.choose.length === 1) {
          this.clearSelection();
          this.toggleRowSelection(row, true);
        } else {
          this.toggleRowSelection(row);
        }
      }
      this.$emit('row-click', row, column, event);
    },
    rowContextmenu(row, column, event) {
      this.$emit('row-contextmenu', row, column, event);
    },
    rowDblclick(row, column, event) {
      this.$emit('row-dblclick', row, column, event);
    },
    headerClick(column, event) {
      this.$emit('header-click', column, event);
    },
    headerContextmenu(column, event) {
      this.$emit('header-contextmenu', column, event);
    },
    /* 排序改变 */
    sortChange({column, prop, order}) {
      if (this.$listeners['sort-change']) {
        this.$emit('sort-change', {column, prop, order});
      } else {
        let temp = {};
        temp[this.request.sortName] = order ? prop : undefined;
        temp[this.request.orderName] = order ? {
          ascending: 'asc', descending: 'desc'
        }[order] : undefined;
        this.order = temp;
        this.reload(true);
      }
    },
    filterChange(filters) {
      this.$emit('filter-change', filters);
    },
    /* 单选改变 */
    currentChange(currentRow, oldCurrentRow) {
      this.$emit('update:current', currentRow);
      this.$emit('current-change', currentRow, oldCurrentRow);
    },
    headerDragend(newWidth, oldWidth, column, event) {
      this.$emit('header-dragend', newWidth, oldWidth, column, event);
    },
    expandChange(row, expandedRows) {
      this.$emit('expand-change', row, expandedRows);
    },
    clearSelection() {
      this.$refs.dataTable.clearSelection();
    },
    toggleRowSelection(row, selected) {
      this.$refs.dataTable.toggleRowSelection(row, selected);
    },
    toggleAllSelection() {
      this.$refs.dataTable.toggleAllSelection();
    },
    toggleRowExpansion(row, expanded) {
      this.$refs.dataTable.toggleRowExpansion(row, expanded);
    },
    setCurrentRow(row) {
      this.$refs.dataTable.setCurrentRow(row);
    },
    clearSort() {
      this.$refs.dataTable.clearSort();
    },
    clearFilter(columnKey) {
      this.$refs.dataTable.clearFilter(columnKey);
    },
    doLayout() {
      this.$refs.dataTable.doLayout();
    },
    sort(prop, order) {
      this.$refs.dataTable.sort(prop, order);
    }
  }
}
"},{"version":3,"sources":["index.vue"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAoCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA","file":"index.vue","sourceRoot":"src/components/EleDataTable","sourcesContent":["<!-- 数据表格组件 -->\r\n<template>\r\n <div>\r\n <!-- 表格 -->\r\n <el-table\r\n ref=\"dataTable\" :data=\"list\" v-loading=\"loading\"\r\n :height=\"height\" :max-height=\"maxHeight\" :stripe=\"stripe\"\r\n :border=\"border===undefined?true:border\" :size=\"size\" :fit=\"fit\"\r\n :show-header=\"showHeader\" :highlight-current-row=\"highlightCurrentRow\" :current-row-key=\"currentRowKey\"\r\n :row-class-name=\"rowClassName\" :row-style=\"rowStyle\" :cell-class-name=\"cellClassName\"\r\n :cell-style=\"cellStyle\" :header-row-class-name=\"headerRowClassName\" :header-row-style=\"headerRowStyle\"\r\n :header-cell-class-name=\"headerCellClassName\" :header-cell-style=\"headerCellStyle\"\r\n :row-key=\"rowKey\" :empty-text=\"emptyText\" :default-expand-all=\"defaultExpandAll\"\r\n :expand-row-keys=\"expandRowKeys\" :default-sort=\"defaultSort\" :tooltip-effect=\"tooltipEffect\"\r\n :show-summary=\"showSummary\" :sum-text=\"sumText\" :summary-method=\"summaryMethod\"\r\n :span-method=\"spanMethod\" :select-on-indeterminate=\"selectOnIndeterminate\" :indent=\"indent\"\r\n :lazy=\"lazy\" :load=\"load\" :tree-props=\"treeProps\"\r\n @select=\"select\" @select-all=\"selectAll\" @selection-change=\"selectionChange\"\r\n @cell-mouse-enter=\"cellMouseEnter\" @cell-mouse-leave=\"cellMouseLeave\" @cell-click=\"cellClick\"\r\n @cell-dblclick=\"cellDblclick\" @row-click=\"rowClick\" @row-contextmenu=\"rowContextmenu\"\r\n @row-dblclick=\"rowDblclick\" @header-click=\"headerClick\" @header-contextmenu=\"headerContextmenu\"\r\n @sort-change=\"sortChange\" @filter-change=\"filterChange\" @current-change=\"currentChange\"\r\n @header-dragend=\"headerDragend\" @expand-change=\"expandChange\" style=\"width:100%;\">\r\n <slot v-bind:page=\"page\" v-bind:count=\"count\" v-bind:index=\"tableIndex\"></slot>\r\n <ele-empty slot=\"empty\" :text=\"emptyText\"/>\r\n </el-table>\r\n <!-- 分页组件 -->\r\n <el-pagination\r\n v-if=\"page\" :current-page=\"page.page\" :page-size=\"page.limit\" :total=\"count\"\r\n :background=\"true\" :layout=\"layout\" :page-sizes=\"pageSizes\" :pager-count=\"pagerCount\"\r\n :prev-text=\"prevText\" :next-text=\"nextText\" :hide-on-single-page=\"hideOnSinglePage\"\r\n @size-change=\"pageSizeChange\" @current-change=\"pageCurrentChange\" class=\"ele-pagination-circle\"/>\r\n </div>\r\n</template>\r\n\r\n<script>\r\nexport default {\r\n name: \"EleDataTable\",\r\n props: {\r\n config: { // 数据表格参数配置\r\n type: Object,\r\n default() {\r\n return {}\r\n }\r\n },\r\n data: Array, // 前端分页直接指定数据\r\n choose: Array, // 列表选中数据(多选)\r\n current: Object, // 列表选中数据(单选)\r\n servePage: Boolean, // 强制后端分页\r\n // 表格参数\r\n size: String,\r\n width: [String, Number],\r\n height: [String, Number],\r\n maxHeight: [String, Number],\r\n fit: {\r\n type: Boolean,\r\n default: true\r\n },\r\n stripe: Boolean,\r\n border: {\r\n type: Boolean,\r\n default: true\r\n },\r\n rowKey: [String, Function],\r\n showHeader: {\r\n type: Boolean,\r\n default: true\r\n },\r\n showSummary: Boolean,\r\n sumText: String,\r\n summaryMethod: Function,\r\n rowClassName: [String, Function],\r\n rowStyle: [Object, Function],\r\n cellClassName: [String, Function],\r\n cellStyle: [Object, Function],\r\n headerRowClassName: [String, Function],\r\n headerRowStyle: [Object, Function],\r\n headerCellClassName: [String, Function],\r\n headerCellStyle: [Object, Function],\r\n highlightCurrentRow: Boolean,\r\n currentRowKey: [String, Number],\r\n emptyText: String,\r\n expandRowKeys: Array,\r\n defaultExpandAll: Boolean,\r\n defaultSort: Object,\r\n tooltipEffect: String,\r\n spanMethod: Function,\r\n selectOnIndeterminate: {\r\n type: Boolean,\r\n default: true\r\n },\r\n indent: {\r\n type: Number,\r\n default: 16\r\n },\r\n treeProps: {\r\n type: Object,\r\n default() {\r\n return {\r\n hasChildren: 'hasChildren',\r\n children: 'children'\r\n };\r\n }\r\n },\r\n lazy: Boolean,\r\n load: Function,\r\n // 分页组件参数\r\n pagerCount: {\r\n type: Number,\r\n default: 5\r\n },\r\n layout: {\r\n default: 'total, sizes, prev, pager, next, jumper'\r\n },\r\n pageSizes: Array,\r\n prevText: String,\r\n nextText: String,\r\n hideOnSinglePage: Boolean\r\n },\r\n data() {\r\n // 分页参数\r\n let page = false;\r\n if (this.config.page !== false) {\r\n page = Object.assign({page: 1, limit: 10}, this.config.page === true ? {} : this.config.page);\r\n }\r\n // 请求参数名\r\n let request = Object.assign({\r\n pageName: 'page', limitName: 'limit', sortName: 'sort', orderName: 'order'\r\n }, this.config.request);\r\n return {\r\n loading: false, // 加载状态\r\n mData: [], // 列表数据源(后端)\r\n count: this.data ? this.data.length : 0, // 总数量\r\n page: page, // 分页参数\r\n order: this.config.order ? this.config.order : {}, // 排序参数\r\n request: request // 请求参数名\r\n };\r\n },\r\n computed: {\r\n /* 表格当前显示数据 */\r\n list() {\r\n let allData;\r\n if (this.data) {\r\n allData = this.data;\r\n } else if (this.mData.length < this.count) {\r\n return this.mData;\r\n } else {\r\n allData = this.mData;\r\n }\r\n let sort = this.order[this.request.sortName],\r\n order = this.order[this.request.orderName];\r\n if (this.page) { // 进行前端分页、排序\r\n let start = (this.page.page - 1) * this.page.limit;\r\n let end = start + this.page.limit;\r\n end = end > allData.length ? allData.length : end;\r\n if (sort) {\r\n return allData.sort((a, b) => {\r\n if (b[sort] == a[sort]) return 0;\r\n if (order === 'desc') {\r\n return (a[sort] < b[sort]) ? 1 : -1;\r\n } else {\r\n return (a[sort] < b[sort]) ? -1 : 1;\r\n }\r\n }).slice(start, end);\r\n } else {\r\n return allData.slice(start, end);\r\n }\r\n } else { // 进行前端排序\r\n if (sort) {\r\n return allData.sort((a, b) => {\r\n if (b[sort] == a[sort]) return 0;\r\n if (order === 'desc') {\r\n return (a[sort] < b[sort]) ? 1 : -1;\r\n } else {\r\n return (a[sort] < b[sort]) ? -1 : 1;\r\n }\r\n });\r\n } else {\r\n return allData;\r\n }\r\n }\r\n },\r\n /* 表格索引开始序号 */\r\n tableIndex() {\r\n if (!this.page) return 1;\r\n return (this.page.page - 1) * this.page.limit + 1;\r\n }\r\n },\r\n watch: {\r\n /* 监听数据改变 */\r\n data() {\r\n this.count = this.data.length;\r\n if (this.page) {\r\n let maxPage = Math.ceil(this.count / this.page.limit);\r\n if (maxPage < this.page.page) this.page.page = maxPage || 1;\r\n }\r\n }\r\n },\r\n mounted() {\r\n this.reload(true);\r\n },\r\n methods: {\r\n /* 获取数据 */\r\n reload(first) {\r\n let config;\r\n if (typeof first === 'object') {\r\n config = Object.assign({}, this.config, first);\r\n first = false;\r\n } else {\r\n config = this.config;\r\n }\r\n if (!first) {\r\n // 分页参数\r\n if (config.page) {\r\n this.page = Object.assign({\r\n page: 1, limit: 10\r\n }, this.page || {}, config.page === true ? {} : config.page);\r\n } else if (this.page === false) {\r\n this.page = false;\r\n }\r\n // 排序参数\r\n if (config.order) Object.assign(this.order, config.order);\r\n // 请求参数名\r\n if (config.request) Object.assign(this.request, config.request);\r\n }\r\n if (config.url && (this.servePage || !first || !this.mData.length || this.mData.length < this.count)) { // 后端分页\r\n this.loading = true;\r\n let pageParam = {};\r\n if (this.page) {\r\n pageParam[this.request.pageName] = this.page.page;\r\n pageParam[this.request.limitName] = this.page.limit;\r\n }\r\n let params, data = Object.assign({}, config.where || {}, pageParam, this.order);\r\n if (config.parseParam) data = config.parseParam(data);\r\n let method = config.method ? config.method.toUpperCase() : 'GET';\r\n if (['POST', 'PUT', 'PATCH'].indexOf(method) === -1) {\r\n params = data;\r\n data = undefined;\r\n } else if (config.contentType && config.contentType.toLowerCase().indexOf('form') !== -1) {\r\n let formData = new FormData();\r\n for (let key in data) {\r\n if (!Object.prototype.hasOwnProperty.call(data, key)) continue;\r\n formData.append(key, data[key]);\r\n }\r\n data = formData;\r\n }\r\n this.$http.request({\r\n url: config.url, method: method,\r\n params: params, data: data, headers: config.headers\r\n }).then(res => {\r\n this.loading = false;\r\n if (config.parseData) res.data = config.parseData(res.data);\r\n if (res.data.code === 0) {\r\n this.mData = res.data.data;\r\n this.count = res.data.count || this.mData.length;\r\n if (this.page) {\r\n let maxPage = Math.ceil(this.count / this.page.limit);\r\n if (maxPage < this.page.page) this.page.page = maxPage || 1;\r\n }\r\n this.$emit('done', res.data, this.page ? this.page.page : 1, this.count, this.$refs.dataTable);\r\n } else {\r\n this.$message.error(res.data.msg || '获取数据失败, 正确的状态码为0');\r\n }\r\n }).catch(e => {\r\n this.loading = false;\r\n this.$message.error(e.message);\r\n });\r\n } else { // 前端分页\r\n this.$emit('done', {data: this.list}, this.page ? this.page.page : 1, this.count, this.$refs.dataTable);\r\n }\r\n },\r\n /* 获取列表当前显示数据 */\r\n getData() {\r\n return this.list;\r\n },\r\n /* 获取列表的排序参数 */\r\n getOrder() {\r\n return this.order;\r\n },\r\n /* 获取列表的分页参数 */\r\n getPage() {\r\n return this.page;\r\n },\r\n /* 分页limit改变 */\r\n pageSizeChange(limit) {\r\n this.page.limit = limit;\r\n this.reload(true);\r\n },\r\n /* 分页page改变 */\r\n pageCurrentChange(page) {\r\n this.page.page = page;\r\n this.reload(true);\r\n },\r\n select(selection, row) {\r\n this.$emit('select', selection, row);\r\n },\r\n selectAll(selection) {\r\n this.$emit('select-all', selection);\r\n },\r\n /* 多选改变 */\r\n selectionChange(selection) {\r\n this.$emit('update:choose', selection);\r\n this.$emit('selection-change', selection);\r\n },\r\n cellMouseEnter(row, column, cell, event) {\r\n this.$emit('cell-mouse-enter', row, column, cell, event);\r\n },\r\n cellMouseLeave(row, column, cell, event) {\r\n this.$emit('cell-mouse-leave', row, column, cell, event);\r\n },\r\n cellClick(row, column, cell, event) {\r\n this.$emit('cell-click', row, column, cell, event);\r\n },\r\n cellDblclick(row, column, cell, event) {\r\n this.$emit('cell-dblclick', row, column, cell, event);\r\n },\r\n /* 行点击事件 */\r\n rowClick(row, column, event) {\r\n if (this.highlightCurrentRow) {\r\n if (this.choose.length === 0 || this.choose.length === 1) {\r\n this.clearSelection();\r\n this.toggleRowSelection(row, true);\r\n } else {\r\n this.toggleRowSelection(row);\r\n }\r\n }\r\n this.$emit('row-click', row, column, event);\r\n },\r\n rowContextmenu(row, column, event) {\r\n this.$emit('row-contextmenu', row, column, event);\r\n },\r\n rowDblclick(row, column, event) {\r\n this.$emit('row-dblclick', row, column, event);\r\n },\r\n headerClick(column, event) {\r\n this.$emit('header-click', column, event);\r\n },\r\n headerContextmenu(column, event) {\r\n this.$emit('header-contextmenu', column, event);\r\n },\r\n /* 排序改变 */\r\n sortChange({column, prop, order}) {\r\n if (this.$listeners['sort-change']) {\r\n this.$emit('sort-change', {column, prop, order});\r\n } else {\r\n let temp = {};\r\n temp[this.request.sortName] = order ? prop : undefined;\r\n temp[this.request.orderName] = order ? {\r\n ascending: 'asc', descending: 'desc'\r\n }[order] : undefined;\r\n this.order = temp;\r\n this.reload(true);\r\n }\r\n },\r\n filterChange(filters) {\r\n this.$emit('filter-change', filters);\r\n },\r\n /* 单选改变 */\r\n currentChange(currentRow, oldCurrentRow) {\r\n this.$emit('update:current', currentRow);\r\n this.$emit('current-change', currentRow, oldCurrentRow);\r\n },\r\n headerDragend(newWidth, oldWidth, column, event) {\r\n this.$emit('header-dragend', newWidth, oldWidth, column, event);\r\n },\r\n expandChange(row, expandedRows) {\r\n this.$emit('expand-change', row, expandedRows);\r\n },\r\n clearSelection() {\r\n this.$refs.dataTable.clearSelection();\r\n },\r\n toggleRowSelection(row, selected) {\r\n this.$refs.dataTable.toggleRowSelection(row, selected);\r\n },\r\n toggleAllSelection() {\r\n this.$refs.dataTable.toggleAllSelection();\r\n },\r\n toggleRowExpansion(row, expanded) {\r\n this.$refs.dataTable.toggleRowExpansion(row, expanded);\r\n },\r\n setCurrentRow(row) {\r\n this.$refs.dataTable.setCurrentRow(row);\r\n },\r\n clearSort() {\r\n this.$refs.dataTable.clearSort();\r\n },\r\n clearFilter(columnKey) {\r\n this.$refs.dataTable.clearFilter(columnKey);\r\n },\r\n doLayout() {\r\n this.$refs.dataTable.doLayout();\r\n },\r\n sort(prop, order) {\r\n this.$refs.dataTable.sort(prop, order);\r\n }\r\n }\r\n}\r\n</script>\r\n"]}]}