用vue3和antd3二次封装table和分页器组件

项目场景:

如题:

我是一只刚入行不久的程序员新人,因为公司新项目要用vue3和antd3,而且要我封装一个公共的table组件,也是查了很多资料,看了很多大佬的代码,配合自己的修改写出来了,因为刚写出来,可能会有一些冗余代码,大家用的时候可以结合自己做一些修改。
因为是新人写的有点乱…见谅


直接上代码

子组件代码

<template>
  <div class="tablePaganations">
    <!-- 表格 -->
    <a-table
      :data-source="tableData"
      :pagination="false"
      :columns="columns"
      :row-selection="props.isSelect ? rowSelection1 : null" //是否多选
    >
      <template v-slot:[item]="scope" v-for="item in renderArr">
        <slot :name="item" :scope="scope"></slot>
      </template>
    </a-table>
    <!-- 分页器 -->
    <div class="paginationSetting">
      <div class="paginationSettingtext">
        <span>{{ total }} 条记录 </span>
        <span style="margin-left: 20px">{{ pageCurrent }} /
          {{ total == 0 ? 1 : Math.ceil(total / pageSize) }}</span>
      </div>
      <div class="paginations">
        <a-pagination
          :current="pageCurrent"
          :page-size-options="['5', '10', '20', '30', '40']"
          :total="total"
          show-size-changer
          show-quick-jumper
          :page-size="pageSize"
          @change="pageChange"
        >
          <template slot="buildOptionText" slot-scope="props">
            <span>{{ props.value }}/</span>
          </template>
        </a-pagination>
      </div>
    </div>
  </div>
</template>

<script setup>
import { ref, reactive, useSlots,watch } from "vue";
const props = defineProps({
  Table: Object,
  column: Object,
  isSelect: Boolean,
});
let tableData = ref([]);
let total = ref(0); //多少条数据
const columns = ref([]);
let pageCurrent = ref(1); //当前第几页
let pageSize = ref(10); //每页多少行
if (props.Table.data) { //非空
  tableData.value = props.Table.data; //表单数据
}
if (props.Table.total) { //非空
  total.value = props.Table.total; //表单长度
}
if (props.column) { //非空
  //表单columns
  columns.value = props.column;
}
const slots = useSlots();
const renderArr = Object.keys(slots);
// console.log(renderArr);

const emit = defineEmits(['batch','changePage']) //子传父

const pageChange = (current, pagesize) => {
  //分页器改变事件
  // console.log("current", current, "pageSize", pagesize);
  pageCurrent.value = current;
  if(pageSize.value != pagesize){ //如果每页行数改变,页码改为1
    pageCurrent.value=1
  }
  pageSize.value = pagesize;
  emit('changePage',{pageCurrent:pageCurrent.value,pageSize:pageSize.value})
};
// watch(()=>pageSize.value,(newValue,oldValue)=>{ //监听pageSize的数据改变页码
//   // console.log('当前值',pageSize.value);
//   // console.log('新值',newValue);
//   // console.log('旧值',oldValue);
//   if(pageSize.value==newValue){
//     pageCurrent.value = 1
//     emit('showSize',{pageCurrent:pageCurrent.value,pageSize:pageSize.value})
//   }
// })
// 是否多选
const rowSelection1 = {
  onChange: (selectedRowKeys, selectedRows) => {
    // console.log(selectedRowKeys, selectedRows);
    emit("batch", selectedRowKeys);
  },
  getCheckboxProps: (record) => ({
    disabled: record.name === "Disabled User", // Column configuration not to be checked
    name: record.name,
  }),
};
</script>

<style scoped>
.tablePaganations {
  width: 100%;
  margin-top: 20px;
}
.paginationSetting {
  display: flex;
  justify-content: space-between;
  height: 35px;
  margin-top: 20px;
}
.paginationSettingtext {
  margin-left: 20px;
}
.paginationSettingtext span {
  color: gray;
  line-height: 35px;
}
.paginations {
  margin-right: 20px;
}
</style>

父组件代码,传的值和column我就不放在上面

<script setup>
const changePage = (val) =>{ //分页器改变返回值
  console.log('changePage',val);
}
const batch =(val)=>{ //多选改变返回值
  console.log('batch',val);
}
</script>
<template>
<div class="vue3_content">
            <!-- 二次封装的table组件 -->
            <tablePaganations
              :Table="tableValues"
              :column="columns"
              :isSelect="isSelect" //是否打开多选框
              @changePage="changePage"
              @batch="batch"
            >
            //这里是插槽,用于对表格进行操作,比如数据渲染和操作列的增删改查
              <template v-slot:bodyCell="{ scope }">
                <span v-if="scope.column.key!='action'">{{ setSlot(scope.column.key, scope.value) }}</span>
                //这里的action是操作列,判断是否为操作列对其进行修改
                <span v-else>
                  <a-button type="primary">编辑</a-button>
                  <a-divider type="vertical" />
                  <a-button>删除</a-button>
                </span>
              </template>
            </tablePaganations>
            <!-- --------------- -->
          </div>
</template>

最终效果:

完整版
用vue3和antd3二次封装table和分页器组件_第1张图片
不加插槽的效果:
用vue3和antd3二次封装table和分页器组件_第2张图片
感谢

你可能感兴趣的:(vue)