zoukankan      html  css  js  c++  java
  • 翻页导航条页码计算方法

    在开发搜索引擎等应用时,提供一个翻页导航条是必须的。我看过网上一些相关的代码,搞得很复杂。晕~~~ 其实其数学计算公式非常简单,本文提供两种最常用的算法。

    翻页式

    样式如下。每次显示10个页码,并提供"前十"、"后十"翻页。
    [1] 2 3 4 5 6 7 8 9 10 下十页 末页
    1 2 3 4 5 6 [7] 8 9 10 下十页 末页
    1 2 3 4 5 6 7 8 9 [10] 下十页 末页
    首页 前十页 [11] 12 13 14 15 16 17 18 19 20 下十页 末页
    首页 前十页 11 12 13 14 15 [16] 17 18 19 20 下十页 末页

    计算公式:(当前页序号最小值为1)
    int x = 当前页序号 / 10;
    if (当前页序号 % 10 == 0) --x;
    int startPage = (x * 10) + 1;
    int endPage = Math.Min(总页数, startPage + 9);

    生成翻页式导航代码演示:
    private string GetNavBarHtml(string s, int pageIndex, int pageCount)
    {
        // 计算显示页码
        int x = pageIndex / 10;
        if (pageIndex % 10 == 0) --x;
        int startPage = (x * 10) + 1;
        int endPage = Math.Min(pageCount, startPage + 9);

        // 生成换页代码
        System.Text.StringBuilder sb = new StringBuilder();
        string url = "<a href = \"search.aspx?s={1}&page={2}\">{0}</a>";

        if (startPage > 1)
        {
          sb.Append(String.Format(url, "首页", s, 1));
          sb.Append("&nbsp");
          sb.Append(String.Format(url, "前十页", s, startPage - 1));
          sb.Append("&nbsp");
        }
        
        for (int i = startPage; i <= endPage; i++)
        {
          if (i != pageIndex)
            sb.Append(String.Format(url, i, s, i));
          else
            sb.Append(string.Format("[{0}]", i));
          
          sb.Append("&nbsp");
        }

        if (pageCount > endPage)
        {
          sb.Append(String.Format(url, "后十页", s, endPage + 1));
          sb.Append("&nbsp");
          sb.Append(String.Format(url, "末页", s, pageCount));
        }
        
        return sb.ToString();
    }

    滚动式

    样式如下。将当前页码放在中间,滚动两端页码。
    [1] 2 3 4 5 6 7 8 9 10 末页
    1 2 3 4 [5] 6 7 8 9 10 末页
    首页 2 3 4 5 [6] 7 8 9 10 11 末页
    首页 5 6 7 8 [9] 10 11 12 13 14 末页
    首页 8 9 10 11 [12] 13 14 15 16 17 末页

    计算公式:(当前页序号最小值为1)
    int startPage = Math.Max(当前页序号 - 4, 1);
    int endPage = Math.Min(页总数, startPage + 9);

    生成滚动式导航代码演示:
    private string GetNavBarHtml(string s, int pageIndex, int pageCount)
    {
        // 计算显示页码
        int startPage = Math.Max(pageIndex - 4, 1);
        int endPage = Math.Min(pageCount, startPage + 9);

        // 生成换页代码
        System.Text.StringBuilder sb = new StringBuilder();
        string url = "<a href = \"search.aspx?s={1}&page={2}\">{0}</a>";

        if (startPage > 1)
        {
          sb.Append(String.Format(url, "首页", s, 1));
          sb.Append("&nbsp");
        }
        
        for (int i = startPage; i <= endPage; i++)
        {
          if (i != pageIndex)
            sb.Append(String.Format(url, i, s, i));
          else
            sb.Append(string.Format("[{0}]", i));
          
          sb.Append("&nbsp");
        }

        if (pageCount > endPage)
        {
          sb.Append(String.Format(url, "末页", s, pageCount));
        }
        
        return sb.ToString();
    }
  • 相关阅读:
    软件测试原则
    java知识点
    jquery取值
    Javaweb命名规则
    @ResponseBody
    jquery ajax 方法及各参数详解
    @RequestMapping用法详解
    eclipse+android+opencv环境搭建的步骤
    Java中的内部类(回调)
    OpenCV直方图(直方图、直方图均衡,直方图匹配,原理、实现)
  • 原文地址:https://www.cnblogs.com/0000/p/1619060.html
Copyright © 2011-2022 走看看