react基于antd二次封装分页组件Pagination
2023-12-19 22:30:58
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>
)
}
文章来源:https://blog.csdn.net/weixin_43845137/article/details/135087946
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。 如若内容造成侵权/违法违规/事实不符,请联系我的编程经验分享网邮箱:veading@qq.com进行投诉反馈,一经查实,立即删除!
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。 如若内容造成侵权/违法违规/事实不符,请联系我的编程经验分享网邮箱:veading@qq.com进行投诉反馈,一经查实,立即删除!