首页 > 其他分享 >定制栏目 --- 关于el-table 的显示隐藏的列

定制栏目 --- 关于el-table 的显示隐藏的列

时间:2023-12-29 15:33:24浏览次数:26  
标签:el const data value --- params table type row

 

  <el-button  type="primary" plain icon="el-icon-s-operation" @click="columsVisible = true" :loading="handleTotalChecked">定制栏目</el-button>   需要的页面引入组件: <div class="tableList">             <tableList ref="tableList" @handleaPage="getPage" @handleParamsQuery="paymentpage" @handleNo="handleApplyNo" @handleSelect="selectHandle" :columnsList="columnsList" @handleSelectListId="selectTableListId" @handleRowSee ="rowSee"></tableList>         </div>  <BaseCustomColumns v-if="columsVisible" ref="customerColumns"  :visible="columsVisible" :columns.sync="columnsList" :columns_copy="columnsList_copy" :tablePath="tablePath" @close=" columsVisible= false" @resetAll="resetAll"/>   import BaseCustomColumns from "@/components/Base/BaseCustomColumns/index.vue"; import tableList  from "./table.vue";   data(){   return {       columnsList: paymenntColumnList,     tablePath: '/settleAccounts/payment',     columsVisible: false,     columnsList_copy: [],   } }  created(){   this.columnsList_copy = deepClone(this.columnsList);   if(this.$route.name.includes('Panymentaudit')){    //判断是新增还是详情             this.panymentAuditInfo=1;             this.getQuery()         }else{             this.getQuery()         } }  // 获取到的更新页码数据         getPage(val){             let params={                ...this.formInline,                 pageNo:val.pageNo,                 pageSize:val.pageSize             }             this.$refs.tableList.searchData(params);         },    // 更新页码后,获取顶部搜索数据         paymentpage(){             this.$nextTick(()=>{                 this.$refs.tableList.getParamsData(this.ruleForm);             })         }, // 获取到的更新页码数据         getPage(val){             let params={                ...this.formInline,                 pageNo:val.pageNo,                 pageSize:val.pageSize             }             this.$refs.tableList.searchData(params);         }, // 点击表格         handleApplyNo(row){             if(this.$route.name.includes('Panymentaudit')){                 this.$router.push({                     path:`/settleAccounts/paymentDetial/${row.applyNo}`,                     query: {                         tranPaymentId:row.tranPaymentId,                         applyNo:row.applyNo,                         editType:"edit",
                    }                 })            }else{                 this.$router.push({                     path:`/settleAccounts/paymentDetial/${row.applyNo}`,                     query: {                         tranPaymentId:row.tranPaymentId,                         editType:"edit",                         showInfo:true,                         // paymentCorpName:row.nameCn,                         // paymentCorpId:row.paymentCorpId,
                    }                 })            }         },   selectHandle(val){             this.ids = val.ids;             this.selectList = val.list;         },    selectTableListId(val){           if(val.data.length==0){             this.$message.warning("请勾选一条或多条数据!");             return  false           }else{
            if(val.val=='delete'){               let params={                 ids:val.data.toString()               }               this.$confirm("此操作将删除数据,是否继续?", "提示", {                 confirmButtonText: "确定",                 cancelButtonText: "取消",                 type: "warning",               })                 .then(() => {                   salesLeadsdelete(params).then((res) => {                     if (res.code == 0) {                       this.$message.success("删除成功!");                       this.paymentpage();                     }                   });                 })             }else{               this.salesDialogVisible = true;                this.$nextTick(()=>{                 this.$refs.salesTransfer.salesTranfer(val.data)               })              }
          }         }, // 行 预览     async rowSee(row){         if(!row.openReportId){             this.$message.warning("请去详情选择格式!");             return false         }         let params={             linkId:row.tranPaymentId,             openReportId:row.openReportId,             type:"I"         }         let location= await getReportUrlByType(params);         if(location.code==0){             this.dialogVisible=true;             this.totalUrl = location.data         }     }, // 保存列宽度         headerDragend(newWidth, oldWidth, column, event) {             const { property } = column             this.columnsList.forEach(r => {                 if (property === r.columns) {                 r.columWidth = newWidth                 }             })             this.getAddTableList()         },          // 保存定制         getAddTableList() {             getAddTableList(this.columnsList, this.tablePath).then((res) => {             });         },         resetAll() {             this.columnsList = deepClone(this.columnsList_copy)         },    //查询自定义列数据          getQuery() {           let params = {               tablePath: this.tablePath,             }
        getTableList(params).then((res) => {             const { code, data } = res             if (code === 0 && data && data.length > 0) {               let arr = []
              data.forEach(r => {                 this.columnsList_copy.forEach((r1, i1) => {                   if (r1.columns === r.columns) {                     const { columShow, columWidth, ...rest } = r                     arr.push({...rest, ...r1, columShow, columWidth})                   }                 })               })
              // 判断是否有新加的field               this.columnsList_copy.forEach((r1, i1) => {                 if (!data.some(r => r1.columns === r.columns)) {                   arr.push(r1)                 }               })
              this.$nextTick(() => {                 this.columnsList = arr               })             } else {               this.columnsList = deepClone(this.columnsList_copy)             }           });         }, ============================================================================================================================================ BaseCustomColumns : <template>   <BaseDialog     :title="title"     :visible="visible2"     width="970px"     :slotFooter="true"     @close="close"     @submit="submit"   >     <div class="content cc">       <div class="cc-top">         <draggable           :list="showColumns"           class="list-group group1"           ghost-class="ghost"           chosenClass="chosenClass"           :group="{name: 'group', pull: true, put: true}"           @start="dragging = true"           @end="dragging = false"         >           <div class="cc-item" :class="item.showType == 1 ? 'col1' : 'col2'" v-for="(item, index) in showColumns" :key="item.labels">             <p class="cc-field" title="可拖动进行顺序调整">{{ item.labels }}</p>             <i class="el-icon-close cc-icon" title="隐藏" @click="showField(index, 1)"></i>           </div>         </draggable>       </div>
      <el-divider>拖至上方显示,拖至下方不显示</el-divider>
      <div class="cc-bottem">         <draggable           :list="hiddenColumns"           class="list-group group2"           ghost-class="ghost"           :group="{name: 'group', pull: true, put: true}"           @start="dragging = true"           @end="dragging = false"           :move="onMove"         >           <div class="cc-item" :class="item.showType == 2 ? 'col2' : 'col1'" v-for="(item, index) in hiddenColumns" :key="item.labels">             <p class="cc-field" title="可拖动至上方">{{ item.labels }}</p>             <i class="el-icon-plus cc-icon" title="显示" @click="showField(index, 2)"></i>           </div>         </draggable>       </div>     </div>
    <template v-slot:slotFooter>       <div class="footer">         <el-button @click="close" title="关闭弹窗">取 消</el-button>         <el-button type="primary" plain @click="reset" title="重置当前变更">重 置</el-button>         <el-button type="primary" @click="submit" :loading="loading" title="保存才能生效喔">保 存</el-button>
        <div class="other-footer">           <el-link :underline="false" type="primary" title="列表回到初始状态" @click="resetAll" style="margin-right: 14px;">还原定制</el-link>           <el-link :underline="false" type="primary" title="显示全部字段" @click="addAll">添加全部</el-link>         </div>       </div>     </template>   </BaseDialog> </template>
<script> // 公用的定制栏目 import BaseDialog from '@/components/BaseDialog/index.vue' import draggable from 'vuedraggable' import { deepClone } from '@/utils'; import { getAddTableList, getDeleteTable } from "@/api/fileManagement/routeCode";
export default {   props: {     visible: false,     title: {       type: String,       default: () => '定制栏目'     },     columns: {       type: Array,       default: () => [],     },     columns_copy: {       type: Array,       default: () => [],     },     tablePath: ''   },   data() {     return {       visible2: this.visible,       saveColumns: [],       showColumns: [],       hiddenColumns: [],       loading: false     };   },   components: {BaseDialog, draggable},   watch: {     columns: function() {       this.init()     }   },   created() {     this.init()   },   methods: {     init() {       this.saveColumns = deepClone(this.columns)       this.showColumns = []       this.hiddenColumns = []
      let arr2 = []       this.saveColumns.forEach(r => {         const row = deepClone(r)
        const copy_row = this.columns_copy.find(r1 => r1.columns === r.columns)         if (copy_row) {           row.showType = copy_row.columShow == 'true' ? 1 : 2         }
        if (row.columShow == 'true') {           this.showColumns.push(row)         } else {           arr2.push(row)         }       })
      let arr = [], arr1 = []       arr2.forEach((r, i) => {         if (r.showType == 1) {           arr.push(r)         } else {           arr1.push(r)         }       })
      this.hiddenColumns = [...arr, ...arr1]     },     close() {       this.visible2 = false       this.$emit('close')     },     // 保存     submit() {       // 设置状态       this.changeColumShow()
      const list = [...this.showColumns, ...this.hiddenColumns], arr = []       list.forEach(r => {         if (r.children && r.children.length) {           r.children.forEach(r1 => {             const { prop, columns,  minWidth, columWidth, label, labels } = r1             arr.push({columns: prop || columns, columWidth: minWidth || columWidth, columSort: '1', columShow: 'hidden', labels: label || labels})           })         }       })       getAddTableList(arr.concat(list), this.tablePath).then((res) => {         const {code} = res         if (code === 0) {           this.$message.success("定制成功!");           this.close()           this.$emit('update:columns', list)           this.$emit('submit')         }       });     },     addAll() {       this.showColumns.push(...this.hiddenColumns)       this.hiddenColumns = []     },     reset() {       this.init()     },     // 还原所有     resetAll() {       this.$confirm("此操作将还原定制,是否继续?", "提示", {         confirmButtonText: "确定",         cancelButtonText: "取消",         type: "warning",       })         .then(() => {           getDeleteTable(this.tablePath).then((res) => {             const {code} = res             if (code == 0) {               this.$message.success("还原成功!");               this.$emit('resetAll')               this.close()             }           });         })         .catch((err) => {         });     },     showField(i, type) {       const name = type === 1 ? 'showColumns':'hiddenColumns'       const row = this[name][i]       this[type === 1 ? 'hiddenColumns':'showColumns'][type === 1 ? 'unshift':'push']({...row})       this[name].splice(i, 1)     },     onMove(e) {       if (e.to.className.includes('group2')) return false;       return true     },     changeColumShow() {       this.showColumns.forEach(r => r.columShow = 'true')       this.hiddenColumns.forEach(r => r.columShow = 'false')     }   }, }; </script>
<style scoped lang="scss"> .content {   padding: 0 5px 10px;   text-align: left; } .cc {   min-height: 320px;   .list-group {     display: flex;     flex-wrap: wrap;   }   .cc-item {     display: flex;     align-items: center;     font-size: 14px;     border-radius: 4px;     overflow: hidden;     &:hover {       background-color: var(--current-color);       color: #fff;     }     .cc-field {       padding: 6px 0px 6px 12px;       cursor: grab;       margin: 0;     }     .cc-icon {       padding: 6px 6px 6px 6px;       cursor: pointer;     }   }   .cc-item  {     margin: 0 16px 16px 0;   }
  .col1 {     color: #000;     background-color: #F1EFF3;     &:hover {       .cc-icon {         color: #fff;       }     }     .cc-icon {       color: #4b4b4b;     }   }   .col2 {     border: 1px solid var(--current-color);     color: var(--current-color);     background-color: var(--current-BGColor, #eef3ff);     .cc-field {       padding: 5px 0px 5px 12px;     }     .cc-icon {       padding: 5px 5px 5px 6px;     }   } } .footer {   text-align: center;   display: block;   // padding: 0px 20px 20px;   position: relative;   .other-footer {     position: absolute;     right: 20px;     top: 2px;   } }
.chosenClass {   // }
::v-deep .el-divider {   margin-bottom: 40px; } ::v-deep .el-divider__text {   color: #ccc; } </style>   分列  引用到的插件数据: import BaseDialog from '@/components/BaseDialog/index.vue' import draggable from 'vuedraggable' import { deepClone } from '@/utils'; import { getAddTableList, getDeleteTable } from "@/api/fileManagement/routeCode"; ============================================================================================================= BaseDialog : <template>   <el-dialog     :title="title"     :visible.sync="visible"     :width="width"     :before-close="handleClose"     :append-to-body="true"     :close-on-click-modal="false"     :destroy-on-close="destroyOnClose"     :modal="modal"     :show-close="showClose"     v-dialogDrag="drag"     ref="dialogRef"   >     <div class="center-box">       <slot></slot>     </div>
    <template v-if="slotFooter">       <slot slot="footer" name="slotFooter"></slot>     </template>     <template v-else>       <span slot="footer" class="dialog-footer" v-if="!hiddenFooter">         <el-button @click="handleClose" v-if="showCancel">{{ cancelText }}</el-button>         <el-button type="primary" @click="submit" :loading="loading" v-if="showConfirm" :disabled="confirmDisabled">{{ confirmText }}</el-button>       </span>     </template>   </el-dialog> </template> <script>
export default {   props: {     visible: false,     title: '',     width: '',     // 是否隐藏footer     hiddenFooter: {       type: Boolean,       default: false     },     destroyOnClose: {       type: Boolean,       default: true     },     // 确定后的loading状态     loading: false,     // 插槽footer,为true得自己配置footer, name为slotFooter     slotFooter: false,     // 是否显示确认     showConfirm: {       type: Boolean,       default: true     },     // 是否显示取消     showCancel: {       type: Boolean,       default: true     },     // 是否显示遮罩层     modal: {       type: Boolean,       default: false     },     // 是否显示右上角x     showClose: {       type: Boolean,       default: true     },     // 默认的取消按钮文本     cancelText: {       type: String,       default: '取 消'     },     // 默认的确定按钮文本     confirmText: {       type: String,       default: '确 定'     },     // 是否拖拽     drag: {       type: Boolean,       default: true     },     // 确定按钮是否禁用     confirmDisabled: {       type: Boolean,       default: false     }   },   data() {     return {     };   },   created(){   },   beforeDestroy() {     this.destory()   },   deactivated() {     this.destory()   },   methods: {     handleClose() {       this.$emit("close");     },     submit() {       this.$emit("submit");     },     destory() {       // 没有no-close类名,才执行关闭事件       if (!this.$refs.dialogRef.$el.classList.contains('no-close')) this.handleClose()     }   }, }; </script>
<style lang="scss" scoped> ::v-deep .el-dialog__footer {   text-align: center;   clear: both; } </style> ============================================================================================= draggable: declare module 'vuedraggable' {   import Vue, { VueConstructor } from 'vue';
  type CombinedVueInstance<     Instance extends Vue,     Data,     Methods,     Computed,     Props   > = Data & Methods & Computed & Props & Instance;
  type ExtendedVue<     Instance extends Vue,     Data,     Methods,     Computed,     Props   > = VueConstructor<     CombinedVueInstance<Instance, Data, Methods, Computed, Props> & Vue   >;
  export type DraggedContext<T> = {     index: number;     futureIndex: number;     element: T;   };
  export type DropContext<T> = {     index: number;     component: Vue;     element: T;   };
  export type Rectangle = {     top: number;     right: number;     bottom: number;     left: number;     width: number;     height: number;   };
  export type MoveEvent<T> = {     originalEvent: DragEvent;     dragged: Element;     draggedContext: DraggedContext<T>;     draggedRect: Rectangle;     related: Element;     relatedContext: DropContext<T>;     relatedRect: Rectangle;     from: Element;     to: Element;     willInsertAfter: boolean;     isTrusted: boolean;   };
  const draggable: ExtendedVue<     Vue,     {},     {},     {},     {       options: any;       list: any[];       value: any[];       noTransitionOnDrag?: boolean;       clone: any;       tag?: string | null;       move: any;       componentData: any;     }   >;
  export default draggable; } ====================================================================== deepClone : // 深拷贝对象 // https://github.com/JakHuang/form-generator/blob/dev/src/utils/index.js#L107 export function deepClone(obj) {   const _toString = Object.prototype.toString
  // null, undefined, non-object, function   if (!obj || typeof obj !== 'object') {     return obj   }
  // DOM Node   if (obj.nodeType && 'cloneNode' in obj) {     return obj.cloneNode(true)   }
  // Date   if (_toString.call(obj) === '[object Date]') {     return new Date(obj.getTime())   }
  // RegExp   if (_toString.call(obj) === '[object RegExp]') {     const flags = []     if (obj.global) { flags.push('g') }     if (obj.multiline) { flags.push('m') }     if (obj.ignoreCase) { flags.push('i') }
    return new RegExp(obj.source, flags.join(''))   }
  const result = Array.isArray(obj) ? [] : obj.constructor ? new obj.constructor() : {}
  for (const key in obj) {     result[key] = deepClone(obj[key])   }
  return result } ========================================================================== // 创建表格设置 export function getAddTableList(data,tablePath) {   let base64 = encodeURIComponent(tablePath);   return request({     url: admin+'/sys/table/create?tablePath='+base64,     method: 'post',     data   }) }   // 删除表格设置(还原定制) export function getDeleteTable(data) {   return request({     url: admin+'/sys/table/delete',     method: 'post',     data   }) }  ==========================================================================================   tableList 组件页面: <template>     <div class="container table-box">         <u-table                 border                 ref="multipleTable"                 :data="tableData"                 highlight-current-row                 @expand-change="handleclick"                 @selection-change="handleSelectionChange"                 :header-cell-style="{background:'#F2F6FF'}"                 :cell-class-name="tableCellStyleName"                 :row-class-name="tableRowStyleName"                 style="width: 100%"                 v-loading="fullscreenLoading"                 :max-height="centerTableHeight"                 @header-dragend="headerDragend"                 @row-dblclick="handleRowClick"                 class="tableMaxHeightClass"                 v-if="refresh"                 use-virtual                 :row-height="uTableRowHeight"                 >                 <!-- use-virtual  虚拟列表重要控件 -->                 <u-table-column                 type="selection"                 width="44"                 class-name="uIndex"                 show-overflow-tooltip                 align="center"                 fixed="left"                 >                 </u-table-column>                 <u-table-column                 label="序号"                 sortable                 type="index"                 width="44"                 align="center"                 >                 </u-table-column>
                <template v-for="(item, index) in columnsList">                     <u-table-column                       :key="index"                       :min-width="item.columWidth"                       v-if="item.columShow == 'true'"                       :prop="item.columns"                       :label="item.labels"                       :formatter="item.formatter"                       show-overflow-tooltip                       sortable                     >                       <template slot-scope="scoped">                         <template v-if="item.columns === 'applyNo'">                             <!-- <el-link @click.native="handleOpenDetial(scoped.row.crmSalesLeadsId,scoped.row)" class="getColor" :underline="false">{{ scoped.row.leadsName}}</el-link> -->                             <span type="primary" @click="handleApplyNo(scoped.row)" style="color:#5231FF;cursor: pointer;" class="textDecoration">{{scoped.row.applyNo}}</span>                         </template>                         <template v-else-if="item.columns === 'arapNo'">                             <span type="primary" @click="handlearapNo(scoped.row)" style="color:#5231FF;cursor: pointer;" class="textDecoration">{{scoped.row.arapNo}}</span>                         </template>                         <template v-else-if="item.columns === 'applyAmount'">                             <el-link :underline="false" style="float:right; font-weight: normal; white-space:nowrap; text-overflow:ellipsis;text-align: right; -o-text-overflow: ellipsis; -ms-text-overflow: ellipsis;overflow:hidden; display: inline-block;">{{scoped.row.applyAmount}}</el-link>                         </template>                         <template v-else-if="item.columns === 'amtStl'">                             <el-link :underline="false" style="float:right;white-space:nowrap;font-weight: normal;text-align: right; text-overflow:ellipsis; -o-text-overflow: ellipsis; -ms-text-overflow: ellipsis;overflow:hidden; display: inline-block; width: 120px;">{{scoped.row.amtStl}}</el-link>                         </template >                         <template v-else-if="item.columns === 'apStatus'">                             <span v-if="scoped.row.apStatus=='未付款'" class="warnningStatus">{{scoped.row.apStatus}}</span>                             <span v-else class="succesStatus">{{scoped.row.apStatus}}</span>                         </template>                         <template v-else-if="item.columns === 'arStatus'">                             <span v-if="scoped.row.arStatus=='未收款'" class="warnningStatus">{{scoped.row.arStatus}}</span>                             <span v-else-if="scoped.row.arStatus=='部分收款'" class="partStatus">{{scoped.row.arStatus}}</span>                             <span v-else class="succesStatus">{{scoped.row.arStatus}}</span>                         </template>                         <template v-else-if="item.columns === 'checkerStatus'">                             <span v-if="scoped.row.checkerStatus=='未审核'" class="warnningStatus" >{{scoped.row.checkerStatus}}</span>                             <span v-else class="succesStatus">{{scoped.row.checkerStatus}}</span>                         </template>                         <template v-else>                           {{scoped.row[item.columns]}}                         </template>                       </template>                     </u-table-column>                   </template>                   <u-table-column                         v-if="panymentAuditInfo==1"                         prop="name"                         label="操作"                         width="120"                         align="center"                         fixed="right"                         >                         <template slot-scope="{row,$index}">                             <div style="white-space:nowrap">                                 <el-link type="primary" @click="checkStatus(row,$index)"  >审核</el-link>                                 <el-link type="primary" @click="handldeRow(row,$index)" >预览</el-link>                                 <el-link type="danger" @click="handleDelete(row,$index)" >删除</el-link>                             </div>                         </template>                     </u-table-column>                     <u-table-column                         v-else                         prop="name"                         label="操作"                         width="120"                         align="center"                         fixed="right">                         <template slot-scope="{row,$index}">                             <div style="white-space:nowrap">                                 <el-link type="primary" @click="handldeRow(row,$index)" >预览</el-link>                                 <el-link type="danger" @click="handleDelete(row,$index)" >删除</el-link>                             </div>                         </template>                     </u-table-column>                 </u-table>                 <pagination class="pagination"                     v-show="total > 0"                     :total="total"                     :page.sync="paramsQuery.pageNo"                     :limit.sync="paramsQuery.pageSize"                     @pagination="fclfeequeryPages"                     @size-change="handleSizeChange"                     @current-change="handlePageChange"                 />     </div> </template> <script> import {fclfeequeryPage,fclfeequerytrend,getEditByPriceId} from "@/api/freightrates/index" import tableConfigMixins from "@/views/mixin/tableConfigMixins"; import {queryPaymentAuditListPage,auditPayment,delPayment} from "@/api/settleAccounts/payment"; import {paymentpage} from "@/api/fileManagement/goods"; import {getReportUrlByType} from "@/api/freightrates/index"; import tableMixins from "./../receivePayment/tableMixins" import {   getAddTableList } from "@/api/fileManagement/routeCode"; export default {     props: {       columnsList: {         type: Array,         default: () => []       }     },     data(){         return{             panymentAuditInfo:"0",             excelList:[],//勾选云加单的id集合             fullscreenLoading: false,             selectquato:[],             tableData:[],             uTableRowHeight:30,             total: 0,             selectInfoList:[],             paramsQuery:{                 pageNo:1,                 pageSize:30,                 dateType: "2",                 applyNo:"",                 oldApplyNo:"",                 arapNo:"",                 apStatus:"",                 customerId:"",                 customerNameEn:"",                 nos:"",                 endDate:"",                 beginDate:"",                 auditStatus:"",             },             selectList:[],             priceNameList:[],             showtime:[],             refresh: true,             tablePath: '/settleAccounts/payment',             checkIds:[],             multipleSelection:[],             otherHeight: 80,         }     },     watch: {       columnsList: function() {         this.refresh = false         this.$nextTick(() => {           this.refresh = true         })       },         tableData: function(o) {             if (o.length) {                 this.$nextTick(() => {                     this.uTableRowHeight = document.querySelectorAll('.uIndex')?.[1]?.getBoundingClientRect()?.height || 30                 })             }         },     },     mixins: [ tableMixins ],     created(){         // this.fclfeequeryPages();
        if(this.$route.name.includes('Panymentaudit')){             this.panymentAuditInfo=1;         }         this.getUserPageList();     },     methods:{         async getUserPageList(){             let params={                 pageNo:this.paramsQuery.pageNo,                 pageSize:this.paramsQuery.pageSize,             }             this.fullscreenLoading = true;             if(this.panymentAuditInfo==1){                 this.location = await queryPaymentAuditListPage(params);             }else{                 this.location = await paymentpage(params);             }                 if(this.location.code==0){                     this.tableData = this.location.data.list;                     this.total = this.location.data.total || 0;                     this.fullscreenLoading = false;
            }         },         fclfeequeryPages(){             this.$emit("handleParamsQuery");         },         async getParamsData(value){             this.fullscreenLoading = true;             let params = {                 pageNo:this.paramsQuery.pageNo,                 pageSize:this.paramsQuery.pageSize,                 dateType: this.paramsQuery.dateType||value.dateType?value.dateType:"",                 applyNo:this.paramsQuery.applyNo||value.applyNo?value.applyNo:"",                 oldApplyNo:this.paramsQuery.oldApplyNo||value.oldApplyNo?value.oldApplyNo:"",                 arapNo:this.paramsQuery.arapNo||value.arapNo?value.arapNo:"",                 apStatus:this.paramsQuery.apStatus||(value.apStatus>0 ||value.apStatus ==0)?value.apStatus:"",                 customerId:this.paramsQuery.customerId||value.customerId?value.customerId:"",                 customerNameEn:this.paramsQuery.customerNameEn||value.customerNameEn?value.customerNameEn:"",                 nos:this.paramsQuery.nos||value.nos?value.nos:"",                 endDate:this.paramsQuery.endDate||value.selectValue?value.selectValue[1]:"",                 beginDate:this.paramsQuery.beginDate||value.selectValue?value.selectValue[0]:"",                 auditStatus:this.paramsQuery.auditStatus||(value.auditStatus>0 ||value.auditStatus ==0)?value.auditStatus:"",             }             if(this.panymentAuditInfo==1){                 this.location = await queryPaymentAuditListPage(params);             }else{                 this.location = await paymentpage(params);             }             if( this.location.code==0){                 this.tableData =  this.location.data.list;                 this.total =  this.location.data.total || 0;                 this.fullscreenLoading = false;             }         },         // 获取表格页码         pageInfo(){             let params={                 pageNo:this.paramsQuery.pageNo,                 pageSize:this.paramsQuery.pageSize             }             this.$emit("handleaPage",params);         },         handleclick(){
        },         // 勾选         async handleSelectionChange(val){             this.multipleSelection = val;             this.selectquato = val.map((item)=>item.tranPaymentId);             this.selectInfoList=val;             let params={                 ids:this.selectquato,                 list:this.selectInfoList             }             this.$emit("handleSelect",params);         },         // 样式         tableCellStyleName(row, column, rowIndex, columnIndex){         },         tableRowStyleName(row){             if(this.multipleSelection){                 const list=  this.multipleSelection.find(item => item.tranPaymentId == row.row.tranPaymentId)                 if(list){                     return "select-row"                 }             }                 // const isSelect = this.selectList.some(r => r === row.row.crmSalesLeadsId)                 // let otherClass = ''                 // if (isSelect) otherClass = 'select-row'
                // if(row.row.less ==false){                 //     return "rowStyleName " + otherClass;                 // } else {                 //   return otherClass                 // }         },         refashTableData(){             this.fclfeequeryPages();         },
        handlePageChange(currentPage) {             this.paramsQuery.pageNo = currentPage;             // 在此刷新数据             },         handleSizeChange(pageSize) {             this.paramsQuery.pageSize = pageSize;             // 在此刷新数据         },         async searchData(e){             let location = await  fclfeequeryPage(e);             if(location.code==0){                 this.tableData = location.data.list;                 this.total = location.data.total || 0;             }         },         async resetData(e){             let location = await  fclfeequeryPage(e);             if(location.code==0){                 this.tableData = location.data.list;                 this.total = location.data.total || 0;             }         },         // 保存列宽度         headerDragend(newWidth, oldWidth, column, event) {             const { property } = column             this.columnsList.forEach(r => {                 if (property === r.columns) {                 r.columWidth = newWidth                 }             })             this.getAddTableList()         },         // 保存定制         getAddTableList() {             getAddTableList(this.columnsList, this.tablePath).then((res) => {             });         },         resetAll() {             this.columnsList = deepClone(this.columnsList_copy)         },         // 转移按钮获取勾选数据         selectTableList(val){             let params={                 val:val,                 data:this.selectquato,
            }             this.$emit("handleSelectListId",params)         },         // 点击表格 付款申请单号         handleApplyNo(row){             if(this.$route.name.includes('Panymentaudit')){                 this.$router.push({                     path:`/settleAccounts/paymentDetial/${row.applyNo}`,                     query: {                         tranPaymentId:row.tranPaymentId,                         applyNo:row.applyNo,                         editType:"edit",
                    }                 })            }else{                 this.$router.push({                     path:`/settleAccounts/paymentDetial/${row.applyNo}`,                     query: {                         tranPaymentId:row.tranPaymentId,                         editType:"edit",                         showInfo:true,                         from:"free"                         // paymentCorpName:row.nameCn,                         // paymentCorpId:row.paymentCorpId,
                    }                 })            }         },         // 行双击         handleRowClick(row){             this.$router.push({                 path:`/settleAccounts/paymentDetial/${row.applyNo}`,                 query: {                     tranPaymentId:row.tranPaymentId,                     editType: 'edit',                     showInfo:true,                     from:"free"                     // paymentCorpName:row.nameCn,                     // paymentCorpId:row.paymentCorpId                 }             })         },         handlearapNo(e){           this.$router.push({               path:`/settleAccounts/receivePaymentDetail/${e.arapNo}`,               query: {                 tranCollectionPaymentId:e.tranCollectionPaymentId,                 customerName:e.clientName,                 type:"edit",                 customerId:e.clientId               }           })         },         // 行付款申请         checkStatus(row){             this.checkIds=[];             this.checkIds.push(row.tranPaymentId);             if(row.auditStatus==1){                 this.$message.warning("付款申请已审核成功!");                 return false             }             let params={                 auditStatus:1,                 paymentIds: this.checkIds             }             // this.handleChecked = true;             auditPayment(params).then((location)=>{                 if(location.code==0){                     this.$message.success("付款申请审核成功!");                     this.fclfeequeryPages();                 }             }).catch((err)=>{             });;
        },             // 行 预览         async handldeRow(row){             if(!row.openReportId){                 this.$message.warning("请去详情选择格式!");                 return false             }             this.$emit("handleRowSee", row);         },         // 行删除         handleDelete(row){             this.$confirm('删除该数据, 是否继续?', '提示', {                 confirmButtonText: '确定',                 cancelButtonText: '取消',                 type: 'warning'             })             let params={                 ids:row.tranPaymentId,             }             this.$confirm('确认删除?')                 .then(_ => {                     delPayment(params).then((res)=>{                         if(res.code==0){                             this.$message.success("删除成功!");                             this.fclfeequeryPages();                         }                     });                 }).catch(_ => {
            })         },     } } </script> <style scoped lang="scss">     .getColor{         color:#5231FF !important;         font-weight: normal;         &:hover{            text-decoration: underline #5231FF;         }     }     .container{width: 100% !important; margin: auto 0 !important;     }     .tableMaxHeightClass{ margin-bottom: 19px;         ::v-deep .uIndex{             .el-tooltip{                 width: 44px !important;                 min-width: 44px !important;             }         }     } ::v-deep .pagination-container .el-pagination {   bottom: -1px;   right: 19px; } ::v-deep .el-table--medium .el-table__cell{     padding: 0; } .list{     ::v-deep .iconfont{         font-size: 24px;     }     ::v-deep .icon-tubiao{         color:#6288FF;     } } ::v-deep .el-tooltip{     p{padding: 0; margin: 0;} } ::v-deep .baseprice{ background-color: #ff5400 !important;} ::v-deep .el-dialog__header{             padding:20px 0px 10px 0px;             border-bottom:1px solid #C3D1FF;             margin: 0 20px;         } ::v-deep .rowStyleName{     td{       div{         color:#ccc !important;       }       &:nth-of-type(1){         div{             color: #000 !important;         }       }       &:nth-of-type(2){         div{             color: #000 !important;         }       }     }
} ::v-deep .cellStyleName{background:#F3FFFE;} ::v-deep .cellStyleTotalName{  background:#FFF3F3;} ::v-deep .succesStatus{color: #65A304;} ::v-deep .warnningStatus {color: #F20000;} ::v-deep .partStatus{color: #F9B548 ;}
::v-deep .selectRowName{ background-color: var(--current-BGColor2 ) !important;} </style> ================================================================================  tableMixins.js 页面 import { debounce } from 'throttle-debounce' export default {   data() {     return {       centerTableHeight: '400',       otherHeight: 0     };   },   created() {   },   mounted() {     this.setTableHeight()
    window.onresize = debounce(200, () => {       this.setTableHeight()     })   },   methods: {     setTableHeight() {
      this.$nextTick(() => {         setTimeout(() => {           if (document.querySelector('.settleAccounts-warp .table-box .el-table')) {             const { height: bodyH } = document.body.getBoundingClientRect()             const { height: navH } = document.querySelector('.nav-wrapper').getBoundingClientRect()             const { height: centerSearchH } = document.querySelector('.settleAccounts-warp .footerTable .search-box')?.getBoundingClientRect() || {}             const { height: centerPaginationH } = document.querySelector('.settleAccounts-warp .footerTable .pagination')?.getBoundingClientRect() || {}             const { height: topH } = document.querySelector('.settleAccounts-warp .collapse')?.getBoundingClientRect() || {}
            // 实际能使用的总高度             const mainH = bodyH - navH - 20/*每模块的margin总和*/ - (topH || 361)/*top模块的固定高度*/ - (centerSearchH + centerPaginationH + 40)/*center模块的固定高度*/ - this.otherHeight/*其他高度*/
            // center的table高度 最小高度200             const footerH = mainH < 200 ? 200 : mainH             document.querySelector('.settleAccounts-warp .table-box .el-table').style.maxHeight = `${footerH}px`             this.centerTableHeight = footerH           }         },500)       })     }   }, };  

标签:el,const,data,value,---,params,table,type,row
From: https://www.cnblogs.com/rockyjs/p/17934940.html

相关文章

  • PyScript 是一个框架,<py-script></py-script> 标签 html 如何在 PyScript 中使用 Pyth
    PyScript是一个框架,它允许用户使用HTML的界面在浏览器中创建丰富的Python应用程序¹。以下是如何在HTML中运行PyScript的步骤²⁴:1.在HTML文件的`<head>`部分插入以下代码:```html<linkrel="stylesheet"href="https://pyscript.net/alpha/pyscript.css"/><scri......
  • 无涯教程-Java NIO - FileLock(文件锁)
    JavaNIO支持并发和多线程,这使它能够同时处理在多个文件上运行的多个线程,但是在某些情况下,无涯教程要求文件不能被任何线程共享并且不可访问。为了满足这种要求,NIO提供了FileLock的API,该API用于提供对整个文件或部分文件的锁定,以使该文件或其部分不会共享或不可访问。为了提供或......
  • C++ Qt开发:SqlRelationalTable关联表组件
    Qt是一个跨平台C++图形界面开发库,利用Qt可以快速开发跨平台窗体应用程序,在Qt中我们可以通过拖拽的方式将不同组件放到指定的位置,实现图形化开发极大的方便了开发效率,本章将重点介绍SqlRelationalTable关联表组件的常用方法及灵活运用。在上一篇文章中详细介绍了SqlTableModle组......
  • spring-retry 重试机制
    引用pom.xml<dependency><groupId>org.springframework.retry</groupId><artifactId>spring-retry</artifactId><version>1.3.4</version></dependency>注:本人测试使用jdk8例子:publicvoiddemo(Stringstr)......
  • 汇编-CBW将有符号数字节转换为字
     将AL寄存器中的有符号数扩展为AX中的有符号数。如果AL是正数,则AH会被设置为0;如果AL是负数,则AH会被设置为FFH .386.modelflat,stdcalloptioncasemap:none.stack4096IncludeIrvine32.incincludelibIrvine32.libExitProcessPROTO,dwExitCode:DWORD.dat......
  • OI练习记录 - 28/12/2023
    悲报:Div4打寄了......
  • MMGCN: Multi-modal Graph Convolution Network for Personalized Recommendation of
    目录概符号说明MMGCN代码WeiY.,WangX.,NieL.,HeX.,HongR.andChuaT.MMGCN:Multi-modalgraphconvolutionnetworkforpersonalizedrecommendationofmicro-video.MM,2019.概推荐领域里比较早的多模态方法.符号说明\(\mathcal{U}\),userset;\(\mathc......
  • MacOS - Mac应用程序部署Qt框架
    在开发Mac上,由于安装了Qt库,所以一切正常。但是,在您将应用程序运送到的任何Mac上,情况可能并非如此。Qt套件带有一个名为macdeployqt的工具来修复此问题。因此,在终端中,在编译应用程序之后,请执行以下操作:cdmy-cool-app-Desktopmacdeployqtmy-cool-app.app请注意,它也可以用于......
  • ReentrantReadWriteLock源码阅读
    ReentrantReadWriteLock源码阅读目录ReentrantReadWriteLock源码阅读简介例子代码分析总览Syncstate定义lockcount和holdcountSync.HoldCounter类Sync类其他成员变量tryAcquiretryReleasetryAcquireSharedfullTryAcquireSharedtryReleaseSharedtryWriteLocktryReadLockSync类分......
  • DockerCompose中重启某个服务时提示: (iptables failed: iptables --wait -t nat -A D
    场景DockerCompose修改某个服务的配置(添加或编辑端口号映射)后如何重启单个服务使其生效:https://blog.csdn.net/BADAO_LIUMANG_QIZHI/article/details/134666413除了以上重启某个服务的方式外。基于docker-compose的方式,如果只是要单纯的重启某个服务,则可以通过docker-compo......