list 分页_DjangoRestFrameWork 分页组件

768dae91af9bff0453d3c48c5021e63a.png

a315c355ba9d0dcae7c76d420a53d1dc.png

使用DRF的分页之前呢,先来了解下Django自带的分页功能

fromdjango.core.paginator import Paginator,Page
# 一个Page中有  object_list代表当前页的所有对象
#has_next 是不是有下一页
#has_previous 是否有上一页
#next_page_number 下一页的编号
#previous_page_number 上一页的编号
#self.number 当前页的编号
#self.paginator 当前页的分页器
 
# 一个Paginator中的object_list 代表所有未分页对象
#self.per_page 每一页有几个对象
#get_page(self, number): 从分页器中取第几页
#page_range(self): 返回分页列表

Django原生通过Paginator与Page对象完成了分页相关实现

一、DRF对Django的分页的封装

1、在rest_framework.pagination.py 总使用BasePagination类对响应的分类方法进行了实现,其中最主要的是paginate_queryset与get_paginated_response方法,通过类PageNumberPagination、LimitOffsetPagination、CursorPagination实现了基本的分页形式。

当然我们也可以对必要的分页实现进行重写

二、配置全局分页

在settings.py中配置全局分页器

REST_FRAMEWORK= {
    # 全局配置分页
    # 'DEFAULT_PAGINATION_CLASS':'rest_framework.pagination.LimitOffsetPagination',
    # 'DEFAULT_PAGINATION_CLASS':'rest_framework.pagination.PageNumberPagination',
    # 'PAGE_SIZE': 2,
}

在rest_framework.generics.py 中的GenericAPIView类中使用pagination_class= api_settings.DEFAULT_PAGINATION_CLASS声明了默认使用全局分页配置

三、自定义分页

fromrest_framework import pagination
 
classMyPagination(pagination.PageNumberPagination):
    page_size = 3
    page_query_param = 'p'
    page_size_query_param = 'num'

四、视图中配置自定义分页

classCategoryViewSets(viewsets.ModelViewSet):
    queryset = Category.objects.all()
    serializer_class = CategorySerizlizer
    #配置视图类使用的分页
    # pagination_class = MyPagination

4c51d235c7d9c000fd85141a35e6f3be.png
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
JTable 是一个非常常见的 Java Swing 控件,它可以方便地展示数据。如果数据量比较大,我们往往需要进行分页查看。下面是 JTable 分页查询的完整实现: 首先,我们需要定义一个分页类 PagingModel,用来管理分页相关的信息,如当前页码、每页显示的行数、总记录数等等。代码如下: ```java public class PagingModel { private int currentPage; // 当前页码 private int pageSize; // 每页显示的行数 private int totalRecords; // 总记录数 private int totalPages; // 总页数 public PagingModel(int pageSize, int totalRecords) { this.currentPage = 1; this.pageSize = pageSize; this.totalRecords = totalRecords; this.totalPages = (totalRecords + pageSize - 1) / pageSize; } public int getCurrentPage() { return currentPage; } public void setCurrentPage(int currentPage) { this.currentPage = currentPage; } public int getPageSize() { return pageSize; } public void setPageSize(int pageSize) { this.pageSize = pageSize; } public int getTotalRecords() { return totalRecords; } public void setTotalRecords(int totalRecords) { this.totalRecords = totalRecords; this.totalPages = (totalRecords + pageSize - 1) / pageSize; } public int getTotalPages() { return totalPages; } public void setTotalPages(int totalPages) { this.totalPages = totalPages; } public int getFirstResult() { return (currentPage - 1) * pageSize; } public int getMaxResults() { return pageSize; } public boolean isFirstPage() { return currentPage == 1; } public boolean isLastPage() { return currentPage == totalPages; } public void nextPage() { if (!isLastPage()) { currentPage++; } } public void previousPage() { if (!isFirstPage()) { currentPage--; } } } ``` 接下来,我们需要定义一个数据模型类,用来管理 JTable 的数据。代码如下: ```java public class MyTableModel extends AbstractTableModel { private List<Object[]> data; private String[] columnNames; public MyTableModel(List<Object[]> data, String[] columnNames) { this.data = data; this.columnNames = columnNames; } @Override public int getRowCount() { return data.size(); } @Override public int getColumnCount() { return columnNames.length; } @Override public String getColumnName(int columnIndex) { return columnNames[columnIndex]; } @Override public Object getValueAt(int rowIndex, int columnIndex) { return data.get(rowIndex)[columnIndex]; } public void setData(List<Object[]> data) { this.data = data; fireTableDataChanged(); } } ``` 其中,data 是一个 List,用来存储 JTable 的数据。每个元素都是一个 Object[],代表一行数据。columnNames 是一个 String[],用来存储 JTable 的列名。 接下来,我们需要定义一个分页查询的方法,用来查询数据并更新 JTable。代码如下: ```java public void queryDataByPage(int pageNum) { PagingModel pagingModel = new PagingModel(pageSize, totalRecords); pagingModel.setCurrentPage(pageNum); List<Object[]> data = // 执行查询语句,获取数据 myTableModel.setData(data); jTable.setModel(myTableModel); updatePageStatus(pagingModel); } private void updatePageStatus(PagingModel pagingModel) { currentPageLabel.setText(pagingModel.getCurrentPage() + ""); totalPagesLabel.setText(pagingModel.getTotalPages() + ""); totalRecordsLabel.setText(pagingModel.getTotalRecords() + ""); previousButton.setEnabled(!pagingModel.isFirstPage()); nextButton.setEnabled(!pagingModel.isLastPage()); } ``` 其中,pageSize 表示每页显示的行数,totalRecords 表示总记录数。我们先根据当前页码和总记录数计算出总页数,然后执行查询语句,获取数据。最后,更新 JTable 的数据模型和分页相关的信息。 最后,我们需要在界面上添加一些组件,如 JTable、分页按钮、分页信息等等。代码如下: ```java JTable jTable = new JTable(); MyTableModel myTableModel = new MyTableModel(new ArrayList<>(), new String[]{/* 列名 */}); int pageSize = 10; int totalRecords = // 执行查询语句,获取总记录数 PagingModel pagingModel = new PagingModel(pageSize, totalRecords); JButton previousButton = new JButton("上一页"); JButton nextButton = new JButton("下一页"); JLabel currentPageLabel = new JLabel(pagingModel.getCurrentPage() + ""); JLabel totalPagesLabel = new JLabel(pagingModel.getTotalPages() + ""); JLabel totalRecordsLabel = new JLabel(pagingModel.getTotalRecords() + ""); previousButton.addActionListener(e -> { pagingModel.previousPage(); queryDataByPage(pagingModel.getCurrentPage()); }); nextButton.addActionListener(e -> { pagingModel.nextPage(); queryDataByPage(pagingModel.getCurrentPage()); }); JPanel pagePanel = new JPanel(new FlowLayout(FlowLayout.CENTER)); pagePanel.add(previousButton); pagePanel.add(currentPageLabel); pagePanel.add(new JLabel("/")); pagePanel.add(totalPagesLabel); pagePanel.add(nextButton); JPanel infoPanel = new JPanel(new FlowLayout(FlowLayout.CENTER)); infoPanel.add(new JLabel("共 " + totalRecordsLabel + " 条记录")); JFrame frame = new JFrame(); frame.add(new JScrollPane(jTable), BorderLayout.CENTER); frame.add(pagePanel, BorderLayout.SOUTH); frame.add(infoPanel, BorderLayout.NORTH); frame.pack(); frame.setLocationRelativeTo(null); frame.setVisible(true); ``` 其中,上一页和下一页按钮的 ActionListener 中分别调用 queryDataByPage 方法来更新 JTable 和分页信息。界面上方显示分页信息,下方显示 JTable 和分页按钮。 以上就是 JTable 分页查询的完整实现。需要注意的是,这里只是一个简单的示例,实际应用中可能需要处理更多的异常情况和分页相关的细节。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值