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>
    )
}

  • 7
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值