前端element-plus表格分页

作者 : admin 本文共1489个字,预计阅读时间需要4分钟 发布时间: 2023-12-25 共1人阅读

element-plus 前端表格分页

实现思路:

1.定义三个变量

        tableData:存储所有表格数据

        transferData:存储筛选操作之后的数据

        tableShowData:存储当前页需要展示的数据

2.获取每页数据(transferData=>tableShowData)

for (
    let i = (currentPage4.value - 1) * pageSize4.value;
    i < currentPage4.value * pageSize4.value;
    i++
  ) {
    if (transferData.value[i]) {
      tableShowData.value.push(transferData.value[i]);
    }
  }
const tableShowData = computed({
  get() {
    return transferData.value.slice(
      (currentPage4.value - 1) * pageSize4.value,
      currentPage4.value * ppageSize4.value
    );
  },
  set(value) {},
});

3.添加表格可能用到的筛选,排序,多选等功能。

        1.筛选:添加@filter-change=”handleFilterChange”方法。

        handleFilterChange(filter);

const fliterHandLerData: any = ref([]);//保存筛选后的数据
  let emitObj: any = {};//保存筛选条件
  emitObj = _.cloneDeep(filter);//获取筛选条件(filter函数参数)
  if (emitObj[Object.keys(emitObj)[0]].length > 0) {//判断是否需要进行筛选
    for (let item in emitObj) {//循环筛选条件
      tableData.value.forEach((oitem) => {//循环原始数据每条数据
        if (emitObj[item].includes(oitem[item])) {//判断指定字段这时候符合条件
          fliterHandLerData.value.push(oitem);//附和则保存该条数据
        }
      });
    }
    transferData.value = fliterHandLerData.value;//将所有符合条件的数据存放到筛选后的变量中
  } else {//没有筛选或者点击重置的时候直接赋值筛选变量所有数据
    transferData.value = tableData.value;
  }

        2.排序 @sort-change=”sortChange”   

        sortChange = ({ column, prop, order }) =>{}

if (order == "ascending") {
    //升序
    transferData.value.sort((a: any, b: any) => {
      return a[prop] - b[prop];
    });
  } else if (order == "descending") {
    //降序
    transferData.value.sort((a: any, b: any) => {
      return b[prop] - a[prop];
    });
  }

        3.全选通过toggleRowSelection,toggleAllSelection,clearSelection完成全选,清楚全选,选中某条数据操作。前端element-plus表格分页插图

4.完整代码示例


  
  
    
    
    
    
  
  




.box {
  width: 300px;
}
.pieChart {
  width: 400px;
  height: 400px;
}

本站无任何商业行为
个人在线分享 » 前端element-plus表格分页
E-->