田源
2024-03-25 c9b0b820272d4bd8cfcefa3a8c67720124253a6b
表格树
已修改4个文件
107 ■■■■ 文件已修改
Source/ProjectWeb/src/components/dynamic-components/dynamic-TreeTable.vue 22 ●●●● 补丁 | 查看 | 原始文档 | blame | 历史
Source/ProjectWeb/src/components/dynamic-components/dynamic-button.vue 3 ●●●● 补丁 | 查看 | 原始文档 | blame | 历史
Source/ProjectWeb/src/components/dynamic-components/dynamic-table.vue 80 ●●●● 补丁 | 查看 | 原始文档 | blame | 历史
Source/ProjectWeb/src/router/page/index.js 2 ●●● 补丁 | 查看 | 原始文档 | blame | 历史
Source/ProjectWeb/src/components/dynamic-components/dynamic-TreeTable.vue
@@ -72,11 +72,11 @@
        currentPage: 1,
        total: 50,
      },
      simplePage:{
      simplePage: {
        currentPage: 1,
        total: 100,
        pagerCount:4,
        layout:"prev, pager, next"
        pagerCount: 4,
        layout: "prev, pager, next"
      },
      //表格树
      form: {},
@@ -86,7 +86,7 @@
        editBtn: false,
        delBtn: false,
        selection: true,
        tip:false,
        tip: false,
        calcHeight: 15,
        indexFixed: false,
        menuFixed: false,
@@ -183,13 +183,13 @@
      TreeSelectList: []
    }
  },
  watch:{
    parentHeight:{
  watch: {
    parentHeight: {
      handler(newval) {
        if(newval >50){
          this.option.height=newval;
        if (newval > 50) {
          this.option.height = newval;
          //doLayout不生效,手动设置表格高度
          this.$children[0].$children[1].$children[1].$children[0].$el.style.height=newval+'px';
          this.$children[0].$children[1].$children[1].$children[0].$el.style.height = newval + 'px';
          /*this.$nextTick(() => {
            if (this.$refs.dataTable && this.$refs.dataTable.doLayout) {
              this.$refs.dataTable.doLayout();
@@ -198,9 +198,9 @@
        }
      }
    },
    isShow:{
    isShow: {
      handler(newval) {
        if(newval && this.$el.clientHeight>50) {
        if (newval && this.$el.clientHeight > 50) {
          this.parentHeight = this.$el.clientHeight - this.$children[0].$children[1].$children[0].$el.clientHeight - this.$children[0].$children[2].$el.clientHeight - 5;
        }
      }
Source/ProjectWeb/src/components/dynamic-components/dynamic-button.vue
@@ -238,10 +238,9 @@
      } else if (this.type === 'table') {
        const top = basicColumn.filter(item => item.paramVOS.webUiButtonLocation === 'top' || func.isEmpty(item.paramVOS.webUiButtonLocation)); // 过滤出来表格上面区域展示的按钮
        const menu = basicColumn.filter(item => item.paramVOS.webUiButtonLocation === 'menu'); // 过滤出来操作栏展示的按钮
        return {
          top: top,
          menu: menu
          menu: menu,
        };
      }
    }
Source/ProjectWeb/src/components/dynamic-components/dynamic-table.vue
@@ -1,23 +1,25 @@
<template>
    <div class="UI-dynamic" :id="'UI-dynamic-'+areasName+componentVO.oid">
      <avue-crud v-model="form"
                 ref="dataTable"
                 :data="tableList"
                 :option="option"
                 :page.sync="pageType"
                 :table-loading="loading"
                 @selection-change="selectChange">
        <!--top区域按钮-->
        <template slot="menuLeft" slot-scope="scope">
          <dynamic-button LocationType="top" type="table":butttonList="componentVO.buttons" :selectList="selectList"></dynamic-button>
        </template>
  <div :id="'UI-dynamic-'+areasName+componentVO.oid" class="UI-dynamic">
    <avue-crud ref="dataTable"
               v-model="form"
               :data="tableList"
               :option="option"
               :page.sync="pageType"
               :table-loading="loading"
               @selection-change="selectChange">
      <!--top区域按钮-->
      <template slot="menuLeft" slot-scope="scope">
        <dynamic-button :butttonList="componentVO.buttons" :selectList="selectList" LocationType="top"
                        type="table"></dynamic-button>
      </template>
        <!--menu区域按钮-->
        <template slot="menu" slot-scope="scope">
          <dynamic-button :scope="scope" LocationType="menu" type="table":butttonList="componentVO.buttons" :selectList="selectList"></dynamic-button>
        </template>
      </avue-crud>
    </div>
      <!--menu区域按钮-->
      <template slot="menu" slot-scope="scope">
        <dynamic-button :butttonList="componentVO.buttons" :scope="scope" :selectList="selectList" LocationType="menu"
                        type="table"></dynamic-button>
      </template>
    </avue-crud>
  </div>
</template>
<script>
@@ -50,18 +52,18 @@
      type: Boolean,
      default: true
    },
    dataStore:{
    dataStore: {
      //弹窗时按钮所属区域选中数据
      type:Array,
      type: Array,
      default: []
    },
    tableType:{
      type:String
    tableType: {
      type: String
    }
  },
  data() {
    return {
      parentHeight:'100%',//当前组件根节点元素高度
      parentHeight: '100%',//当前组件根节点元素高度
      form: {},
      loading: false,
      page: {
@@ -69,11 +71,11 @@
        currentPage: 1,
        total: 50,
      },
      simplePage:{
      simplePage: {
        currentPage: 1,
        total: 100,
        pagerCount:4,
        layout:"prev, pager, next"
        pagerCount: 4,
        layout: "prev, pager, next"
      },
      //表格数据
      tableList: [
@@ -476,14 +478,14 @@
        editBtn: false,
        delBtn: false,
        selection: true,
        tip:false,
        tip: false,
        height: '100%',
        calcHeight: 15,
        indexFixed: false,
        menuFixed: false,
        column: [],
      },
      selectList:[],
      selectList: [],
    }
  },
  computed: {
@@ -506,13 +508,13 @@
      return this.areasName === 'westArea' ? this.simplePage : this.page;
    }
  },
  watch:{
    parentHeight:{
  watch: {
    parentHeight: {
      handler(newval) {
        if(newval >50){
          this.option.height=newval;
        if (newval > 50) {
          this.option.height = newval;
          //doLayout不生效,手动设置表格高度
          this.$children[0].$children[1].$children[1].$children[0].$el.style.height=newval+'px';
          this.$children[0].$children[1].$children[1].$children[0].$el.style.height = newval + 'px';
          /*this.$nextTick(() => {
            if (this.$refs.dataTable && this.$refs.dataTable.doLayout) {
              this.$refs.dataTable.doLayout();
@@ -521,28 +523,28 @@
        }
      }
    },
    isShow:{
    isShow: {
      handler(newval) {
        if(newval && this.$el.clientHeight>50) {
        if (newval && this.$el.clientHeight > 50) {
          this.parentHeight = this.$el.clientHeight - this.$children[0].$children[1].$children[0].$el.clientHeight - this.$children[0].$children[2].$el.clientHeight - 5;
        }
      }
    }
  },
  created() {
    this.option.column=this.updatedColumns;
    this.option.column = this.updatedColumns;
  },
  mounted() {
    if(this.$el.clientHeight>50) {
    if (this.$el.clientHeight > 50) {
      //父元素高度-按钮高度-分页高度
      this.parentHeight = this.$el.clientHeight - this.$children[0].$children[1].$children[0].$el.clientHeight - this.$children[0].$children[2].$el.clientHeight - 5;
    }
  },
  methods: {
    selectChange(row){
    selectChange(row) {
      this.selectList = row;
    },
    TreeSelectChange(row){
    TreeSelectChange(row) {
      this.TreeSelectList = row;
    }
  }
Source/ProjectWeb/src/router/page/index.js
@@ -90,7 +90,7 @@
    ]
  },
  {
      path: '/dynamic-form',
    path: '/dynamic-form',
    name: '动态表格页面',
    component: Layout,
    children: [