el-pagination分页查询封装

需求:因为需要用到表单查询的地方太多了,所以为了避免每个页面都写分页组件,直接封装好调用就完事了,简简单单

1.创建Pigination.vue公用组件

<template>
  <div :class="{'hidden':hidden}" class="pagination-container">
    <el-pagination
      :background="background"
      :current-page.sync="currentPage"
      :page-size.sync="pageSize"
      :layout="layout"
      :page-sizes="pageSizes"
      :total="total"
      v-bind="$attrs"
      @size-change="handleSizeChange"
      @current-change="handleCurrentChange"
    ></el-pagination>
  </div>
</template>

<script>

export default {
  name: 'Pagination',
  props: {
    total: {
      required: true,
      type: Number
    },
    // 当前页数
    page: {
      type: Number,
      default: 1
    },
    // 限制,一页多多少行
    limit: {
      type: Number,
      default: 20
    },
    // 分页
    pageSizes: {
      type: Array,
      default() {
        return [10, 20, 30, 50, 100]
      }
    },
    layout: {
      type: String,
      default: 'total, sizes, prev, pager, next, jumper'
    },
    background: {
      type: Boolean,
      default: true
    },
    autoScroll: {
      type: Boolean,
      default: true
    },
    hidden: {
      type: Boolean,
      default: false
    }
  },
  computed: {
    // 当前页数
    currentPage: {
      get() {
        return this.page;
      },
      set(val) {
        this.$emit('update:page', val);
      }
    },
    pageSize: {
      get() {
        return this.limit;
      },
      set(val) {
        this.$emit('update:limit', val);
      }
    }
  },
  methods: {
    handleSizeChange(val) {
      this.$emit('pagination', { page: this.currentPage, size: val });
      // if (this.autoScroll) {
      //   scrollTo(0, 800);
      // }
    },
    handleCurrentChange(val) {
      this.$emit('pagination', { page: val, size: this.pageSize });
      // if (this.autoScroll) {
      //   scrollTo(0, 800);
      // }
    }
  }
}
</script>

<style scoped>
.pagination-container {
  background: #fff;
  padding-top: 10px;
}
.pagination-container.hidden {
  display: none;
}
</style>

2.需要使用分页组件的页面调用

<template>
    <div class="content-box">
        <div class="container">
            <p>主体页面 2 - 2</p>

            <div class="table-container">
                <el-table
                    ref="Table2"
                    :data="list"
                    style="width: 100%;"
                    show-overflow-tooltip="true"
                    @selection-change="handleSelectionChange"
                    border
                >
                    <el-table-column type="selection" align="center"></el-table-column>
                    <el-table-column label="操作" width="120" align="center" fixed="right"> </el-table-column>
                </el-table>
            </div>

            <!-- 分页组件 -->
            <Pagination :total="total" :page.sync="listQuery.pageNum" :limit.sync="listQuery.pageSize" @pagination="getList"></Pagination>
        </div>
    </div>
</template>

<script>
import Pagination from '@/components/common/Pagination';
import { testApi } from '@/api/test';
const defaultListQuery = {
    pageNum: 1,//给后端的数据,可以根据后端需要更改
    pageSize: 10,
    keyword: ''
};
export default {
    data() {
        return {
            listQuery: Object.assign({}, defaultListQuery),//浅拷贝,引用数据类型相互影响
            list: [],
            total: 0,
            listLoading: true,
            selectedList: []
        };
    },
    components: {
      // 注册分页
        Pagination
    },
    created() {
        this.getList();
    },
    methods: {
        getList() {
            // 获取数据列表
            this.listLoading = true;
            testApi(this.listQuery).then(res => {
                this.listLoading = false;
                this.list = res.data.list;
                this.total = res.data.total;
            });
        },
        handleSelectionChange(val) {
            // 批量选择行数
            this.selectedList = val;
        }
    }
};
</script>

3.结果

 文章到此结束,希望对你有所帮助~

猜你喜欢

转载自blog.csdn.net/qq_44278289/article/details/131411762