当前位置:首页 > 编程技术 > 正文内容

利用HTML和Java实现简单的下一页功能

2002djc1周前 (09-09)编程技术62

利用HTML和Java实现简单的下一页功能

在Web应用程序中,翻页功能是非常常见的需求,尤其是在处理大量数据时。本文将展示如何使用HTML前端技术配合Java后端逻辑来实现基本的翻页功能。


前端HTML设计

首先,我们需要创建一个简单的HTML页面,用于显示数据列表和翻页控件。

< !DOCTYPE html >
    < html lang = "zh" >
    < head >
    < meta charset = "UTF-8" >
    < title > 翻页示例 < /title> < /head> < body >
    < table border = "1" >
    < thead >
    < tr >
    < th > ID < /th> < th > 名称 < /th> < /tr> < /thead> < tbody id = "data-list" >
    < /tbody> < /table> < div id = "pagination" >
    < button onclick = "navigatePage(1)" > 首页 < /button> < button onclick = "navigatePage(-1)" > 上一页 < /button> < span id = "currentPage" > 1 < /span> < button onclick = "navigatePage(1)" > 下一页 < /button> < button onclick = "navigatePage(-1, true)" > 末页 < /button> < /div>
< script >
    function navigatePage(direction, toLast = false) {
        const currentPageElement = document.getElementById('currentPage');
        let currentPage = parseInt(currentPageElement.textContent);
        if (toLast) {
            // 跳转到最后一页
            currentPage = Math.ceil(totalPages / itemsPerPage);
        } else {
            currentPage += direction;
        }
        currentPage = Math.max(1, currentPage); // 确保不小于1
        currentPageElement.textContent = currentPage;
        fetch(`/getData?page=${currentPage}`)
            .then(response => response.json())
            .then(data => {
                const tbody = document.getElementById('data-list');
                tbody.innerHTML = ''; // 清空表格
                data.forEach(item => {
                    const row = document.createElement('tr');
                    row.innerHTML = `<td>${item.id}</td><td>${item.name}</td>`;
                    tbody.appendChild(row);
                });
            });
    } < /script> < /body> < /html>

后端Java逻辑

接下来,我们来看一下后端Java部分的实现。这里假设你正在使用Spring Boot框架来构建你的后端服务。

import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.RestController;

import java.util.ArrayList;
import java.util.List;

@RestController
public class DataController {

    private List<Item> items = new ArrayList<>();
    
    public DataController() {
        // 初始化数据
        for (int i = 1; i <= 100; i++) {
            items.add(new Item(i, "Item " + i));
        }
    }

    @GetMapping("/getData")
    public List<Item> getData(@RequestParam int page) {
        int pageSize = 10; // 每页显示的数据量
        int start = (page - 1) * pageSize;
        int end = Math.min(start + pageSize, items.size());
        return items.subList(start, end);
    }

    static class Item {
        private int id;
        private String name;

        public Item(int id, String name) {
            this.id = id;
            this.name = name;
        }

        public int getId() {
            return id;
        }

        public String getName() {
            return name;
        }
    }
}

我们创建了一个DataController类来处理HTTP GET请求。这个控制器接收一个名为page的参数,用来确定当前页数。然后根据这个页数从数据库或数据集中获取对应的数据片段,并返回给前端。

本站发布的内容若侵犯到您的权益,请邮件联系站长删除,我们将及时处理!


从您进入本站开始,已表示您已同意接受本站【免责声明】中的一切条款!


本站大部分下载资源收集于网络,不保证其完整性以及安全性,请下载后自行研究。


本站资源仅供学习和交流使用,版权归原作者所有,请勿商业运营、违法使用和传播!请在下载后24小时之内自觉删除。


若作商业用途,请购买正版,由于未及时购买和付费发生的侵权行为,使用者自行承担,概与本站无关。


本文链接:https://10zhan.com/biancheng/11478.html

分享给朋友:

“利用HTML和Java实现简单的下一页功能” 的相关文章

【说站】Thymeleaf报错Error resolving template “XXX”

【说站】Thymeleaf报错Error resolving template “XXX”

修改了一下开源项目的目录结构访问突然报错Error resolving template “XXX”可能原因有如下三种:第一种可能:原因:在使用springboot的过程中,如果使用thymeleaf...

【说站】Centos8.0如何配置静态IP详解及永久关闭防火墙

【说站】Centos8.0如何配置静态IP详解及永久关闭防火墙

这篇文章主要介绍了详解Centos8 配置静态IP的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来学习一下!1. 查看自己的网关地址点击虚...

【说站】利用Webhook实现Java项目自动化部署

【说站】利用Webhook实现Java项目自动化部署

用webhook就能实现Java项目自动部署,其实原理很简单。费话不多说,直接往下看教程。1. 创建gitee仓库并初始化2. 在linux安装git3. 在宝塔的软件的商店里下载Webhook4....

【说站】vagrant实现linux虚拟机的安装并配置网络

【说站】vagrant实现linux虚拟机的安装并配置网络

一、VirtualBox的下载和安装1、下载VirtualBox官网下载:https://www.virtualbox.org/wiki/Downloads我的电脑是Windows的,所以下载Wind...

【说站】C#在PDF中添加墨迹注释Ink Annotation的步骤详解

【说站】C#在PDF中添加墨迹注释Ink Annotation的步骤详解

PDF中的墨迹注释(Ink Annotation),表现为徒手涂鸦式的形状;该类型的注释,可任意指定形状顶点的位置及个数,通过指定的顶点,程序将连接各点绘制成平滑的曲线。下面,通过C#程序代码介绍如何...

【说站】使用systemctl配置dnspod-shell实现ddns

【说站】使用systemctl配置dnspod-shell实现ddns

这个是毛子路由器上用的脚本,由于碳云的nat服务器公网IP不断的变,因此只好通过ddns来稳定连接nat服务器了。顺便水一篇文章,大家新年快乐。使用前需要将域名添加到 DNSPod 中,并添加一条A记...