react基于antd二次封装分页组件Pagination

react基于antd二次封装分页组件Pagination

组件PaginationCom

import {
    Pagination } from 'antd';
import propTypes from "prop-types";
import React from 'react';

const PaginationCom = (props) => {
   
    return (
        <div className='content' style={
   {
   marginTop: '20px'}}>
          <Pagination
              total={
   props.total}
              showSizeChanger={
   props.showSizeChanger}
              showQuickJumper={
   props.showQuickJumper}
              pageSizeOptions={
   props.pageSizeOptions}
              current={
   props.current}
              pageSize={
   props.pageSize}
              showTotal={
   (total) => `${
     total}`}
              onChange={
   props.onChange}
              onShowSizeChange={
   props.onShowSizeChange}
            />
        </div>
    )
}
// props
PaginationCom.propTypes = {
   
  current: propTypes.number.isRequired, // 当前页数
  pageSize: propTypes.number.isRequired,// 每页条数
  total: propTypes.number.isRequired,// 总数
  onChange: propTypes.func.isRequired, // 页码切换
  onShowSizeChange: propTypes.func.isRequired, // 条数切换
  showSizeChanger: propTypes.bool, // 是否展示 pageSize 切换器
  showQuickJumper: propTypes.bool, // 是否可以快速跳转至某页
  pageSizeOptions: propTypes.array,
  size: propTypes.string,
};
// 默认值
PaginationCom.defaultProps = {
   
  current: 1, // 当前页数
  pageSize: 10, // 每页条数
  total: 0, // 默认值
  showSizeChanger: true, // 是否展示 pageSize 切换器
  showQuickJumper: true, // 是否可以快速跳转至某页
  pageSizeOptions: [10,20,50],
};
export default PaginationCom

使用组件

import React, {
    useState } from 'react';
import PaginationCom from "./PaginationCom";
export default function App(props) {
   
  const [page,setPage] = useState(1)
  const [pageSize,setPageSize] = useState(10)
  const pageChange = (page) => {
   
    console.log('pageChange', page);
    setPage(page)
  }
  const pageSizeChange = (page, pageSize) => {
   
    // console.log('pageSizeChange',page,"pageSize",pageSize);
    setPageSize(pageSize)
    // setPage(1) // 没有效果
  }
    return (
        <div className='content'>
          page - {
   page}
          <PaginationCom  total={
   35} current={
   page} pageSize={
   pageSize} onChange={
   pageChange} onShowSizeChange={
   pageSizeChange}></PaginationCom>
        </div>
    )
}

相关推荐

  1. react基于antd封装组件Pagination

    2023-12-20 17:30:02       38 阅读

最近更新

  1. TCP协议是安全的吗?

    2023-12-20 17:30:02       18 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2023-12-20 17:30:02       19 阅读
  3. 【Python教程】压缩PDF文件大小

    2023-12-20 17:30:02       18 阅读
  4. 通过文章id递归查询所有评论(xml)

    2023-12-20 17:30:02       20 阅读

热门阅读

  1. 使用DB1小波进行三层小波分解(Matlab实现)

    2023-12-20 17:30:02       39 阅读
  2. 基于软译码的Hamming信道编码误码率Matlab仿真

    2023-12-20 17:30:02       38 阅读
  3. 力扣 | 347. 前 K 个高频元素

    2023-12-20 17:30:02       35 阅读
  4. VUE2组件按需引用

    2023-12-20 17:30:02       40 阅读
  5. 2024 年 QA 自动化的语言是什么?

    2023-12-20 17:30:02       49 阅读
  6. vivado 用XDC约束IP和子模块

    2023-12-20 17:30:02       28 阅读
  7. 低信噪比环境下的GPS信号识别与捕获技术

    2023-12-20 17:30:02       32 阅读
  8. k8s的API资源对象CustomResourceDefinition(CRD)

    2023-12-20 17:30:02       53 阅读