`
wxq594808632
  • 浏览: 262435 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

仿je分页标签显示

    博客分类:
  • java
阅读更多
这几天一直在看je的分页显示觉得做的非常不错.很合理人性化.于是乎自己也想搞个.网上找了找.貌似je用的是displaytag组件实现的..自己实在是懒.没去看.从网上找了段代码,然后修修补补改成如下格式

不过没有je做的好.有些地方没多想.请大家完善(这里的css是借用je的..robbin老大多包涵)



然后发算法类


package com.smallq.util;

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

public class RefactorPage {
	public static void main(String[] args) {
		List<String> l = RefactorPage.getPageHref(7, 4, "pageAction.do?page");
		for (String s : l) {
			System.out.println(s);
		}
	}

	/**
	 * 分页链接显示
	 * 
	 * @param totalPage
	 * @param page
	 * @param url
	 * @return
	 */
	public static List<String> getPageHref(int totalPage, int page, String url) {
		List<String> list = new ArrayList<String>();
		list.add("<div class='pagination'>");
		// 判断是否首页
		if (page != 1) {
			list.add("<a href=" + url + "=" + (page - 1)
					+ " class='prev_page' rel='prev start'>&laquo; 上一页</a> ");
		} else {
			list.add("<span class='disabled prev_page'>&laquo; 上一页</span> ");
		}
		// 如果总页数小于7,全部输出
		if (totalPage < 7) {
			outAll(totalPage, page, url, list);
		}
		// 如果一共7页
		if (totalPage == 7) {
			// 如果是前两页
			if (page < 3) {
				previousTwoPage(page, url, list);
				addFootPage(totalPage, url, list);
			} else
				// 如果是最后两页
				if (page > totalPage - 2) {
					addHeadPage(url, list);
					lastTwoPage(totalPage, page, url, list);
				} else {
					outAll(totalPage, page, url, list);
				}
		}

		// 如果总页数是8
		if (totalPage == 8) {
			// 如果是前两页
			if (page < 3) {
				previousTwoPage(page, url, list);
				addFootPage(totalPage, url, list);
			} else
				// 如果是最后两页
				if (page > totalPage - 2) {
					addHeadPage(url, list);
					lastTwoPage(totalPage, page, url, list);
					// 第三页
				} else if (page == 3) {
					thirdPage(page, url, list);
					addFootPage(totalPage, url, list);
					// 倒数第三页
				} else if (page == totalPage - 2) {
					countDownThirdPage(totalPage, page, url, list);
				} else {
					{
						outAll(totalPage, page, url, list);
					}
				}
		}

		// 如果总页数是9
		if (totalPage == 9) {
			// 如果是前两页
			if (page < 3) {
				previousTwoPage(page, url, list);
				addFootPage(totalPage, url, list);
			} else
				// 如果是最后两页
				if (page > totalPage - 2) {
					addHeadPage(url, list);
					lastTwoPage(totalPage, page, url, list);
					// 第三页
				} else if (page == 3) {
					thirdPage(page, url, list);
					addFootPage(totalPage, url, list);
					// 倒数第三页
				} else if (page == totalPage - 2) {
					countDownThirdPage(totalPage, page, url, list);
					// 第四页
				} else if (page == 4) {
					forthPage(page, url, list);
					addFootPage(totalPage, url, list);
					// 倒数第四页
				} else if (page == 6) {
					addHeadPage(url, list);
					countDownForthPage(totalPage, page, url, list);
				} else {
					{
						outAll(totalPage, page, url, list);
					}

				}
		}

		// 如果总页数是10
		if (totalPage == 10) {
			// 如果是前两页
			if (page < 3) {
				previousTwoPage(page, url, list);
				addFootPage(totalPage, url, list);
			} else
				// 如果是最后两页
				if (page > totalPage - 2) {
					addHeadPage(url, list);
					lastTwoPage(totalPage, page, url, list);
				} else if (page == 3) {
					thirdPage(page, url, list);
					addFootPage(totalPage, url, list);
				} else if (page == totalPage - 2) {
					countDownThirdPage(totalPage, page, url, list);
				} else if (page == 4) {
					forthPage(page, url, list);
					addFootPage(totalPage, url, list);
				} else if (page == totalPage - 3) {
					addHeadPage(url, list);
					countDownForthPage(totalPage, page, url, list);
				} else if (page == 5) {
					fifthPage(page, url, list);
					addFootPage(totalPage, url, list);
				} else if (page == totalPage - 4) {
					addHeadPage(url, list);
					countDownFifthPage(totalPage, page, url, list);
				} else {
					{
						outAll(totalPage, page, url, list);
					}

				}
		}

		if (totalPage > 10) {

			// 如果是前两页
			if (page < 3) {
				previousTwoPage(page, url, list);
				addFootPage(totalPage, url, list);
			} else
				// 如果是最后两页
				if (page > totalPage - 2) {
					addHeadPage(url, list);
					lastTwoPage(totalPage, page, url, list);
					// 如果是第三页
				} else if (page == 3) {
					thirdPage(page, url, list);
					addFootPage(totalPage, url, list);
				} else if (page == totalPage - 2) {
					countDownThirdPage(totalPage, page, url, list);
					// 第4页
				} else if (page == 4) {
					forthPage(page, url, list);
					addFootPage(totalPage, url, list);
				} else if (page == totalPage - 3) {
					addHeadPage(url, list);
					countDownForthPage(totalPage, page, url, list);
				} else if (page == 5) {
					fifthPage(page, url, list);
					addFootPage(totalPage, url, list);
				} else if (page == totalPage - 4) {
					addHeadPage(url, list);
					countDownFifthPage(totalPage, page, url, list);
				} else {
					addHeadPage(url, list);
					// 中间
					list.add("<a href=" + url + "=" + (page - 1) + ">" + (page - 1)
							+ "</a>");
					list.add("<span class='current'>" + page + "</span>");
					list.add("<a href=" + url + "=" + (page + 1) + ">" + (page + 1)
							+ "</a>");
					// 后段
					addFootPage(totalPage, url, list);
				}
		}
		// 判断是否尾页
		if (page != totalPage) {
			list.add(" <a href=" + url + "=" + (page + 1)
					+ " class='next_page' rel='next'>下一页 &raquo;</a>");
		} else {
			list.add(" <span class='disabled next_page'>下一页 &raquo;</span>");
		}
		list.add("</div>");
		return list;
	}

	/**
	 * 输出全部
	 * 
	 * @param totalPage
	 * @param page
	 * @param url
	 * @param list
	 */
	private static void outAll(int totalPage, int page, String url,
			List<String> list) {
		for (int i = 0; i < totalPage; i++) {
			if ((i + 1) == page) {
				list.add("<span class='current'>" + page + "</span>");
				i = i + 1;
				if (page == totalPage)
					break;
			}
			list.add("<a href=" + url + "=" + (i + 1) + ">" + (i + 1) + "</a>");
		}
	}

	/**
	 * 前两页
	 * 
	 * @param page
	 * @param url
	 * @param list
	 */
	private static void previousTwoPage(int page, String url, List<String> list) {
		for (int i = 0; i < 3; i++) {
			if (i + 1 == page) {
				list.add("<span class='current'>" + page + "</span>");
				i = i + 1;
			}
			list.add("<a href=" + url + "=" + (i + 1) + " rel='next'>"
					+ (i + 1) + "</a>");
		}
	}

	/**
	 * 后两页
	 * 
	 * @param totalPage
	 * @param page
	 * @param url
	 * @param list
	 */
	private static void lastTwoPage(int totalPage, int page, String url,
			List<String> list) {
		for (int i = totalPage - 3; i < totalPage; i++) {
			if (i + 1 == page) {
				list.add("<span class='current'>" + page + "</span>");
				i = i + 1;
				if (page == totalPage)
					break;
			}
			list.add("<a href=" + url + "=" + (i + 1) + ">" + (i + 1) + "</a>");
		}
	}

	/**
	 * 第三页
	 * 
	 * @param page
	 * @param url
	 * @param list
	 */
	private static void thirdPage(int page, String url, List<String> list) {
		for (int i = 0; i < 4; i++) {
			if (i + 1 == page) {
				list.add("<span class='current'>" + page + "</span>");
				i = i + 1;
			}
			list.add("<a href=" + url + "=" + (i + 1) + " rel='next'>"
					+ (i + 1) + "</a>");
		}
	}

	/**
	 * 倒数第三页
	 * 
	 * @param totalPage
	 * @param page
	 * @param url
	 * @param list
	 */
	private static void countDownThirdPage(int totalPage, int page, String url,
			List<String> list) {
		addHeadPage(url, list);
		for (int i = totalPage - 4; i < totalPage; i++) {
			if (i + 1 == page) {
				list.add("<span class='current'>" + page + "</span>");
				i = i + 1;
				if (page == totalPage)
					break;
			}
			list.add("<a href=" + url + "=" + (i + 1) + ">" + (i + 1) + "</a>");
		}
	}

	/**
	 * 第四页
	 * 
	 * @param page
	 * @param url
	 * @param list
	 */
	private static void forthPage(int page, String url, List<String> list) {
		for (int i = 0; i < 5; i++) {
			if (i + 1 == page) {
				list.add("<span class='current'>" + page + "</span>");
				i = i + 1;
			}
			list.add("<a href=" + url + "=" + (i + 1) + " rel='next'>"
					+ (i + 1) + "</a>");
		}
	}

	/**
	 * 倒数第四页
	 * 
	 * @param totalPage
	 * @param page
	 * @param url
	 * @param list
	 */
	private static void countDownForthPage(int totalPage, int page, String url,
			List<String> list) {
		for (int i = totalPage - 5; i < totalPage; i++) {
			if (i + 1 == page) {
				list.add("<span class='current'>" + page + "</span>");
				i = i + 1;
				if (page == totalPage)
					break;
			}
			list.add("<a href=" + url + "=" + (i + 1) + ">" + (i + 1) + "</a>");
		}
	}

	/**
	 * 倒数第五页
	 * 
	 * @param totalPage
	 * @param page
	 * @param url
	 * @param list
	 */
	private static void countDownFifthPage(int totalPage, int page, String url,
			List<String> list) {
		for (int i = totalPage - 6; i < totalPage; i++) {
			if (i + 1 == page) {
				list.add("<span class='current'>" + page + "</span>");
				i = i + 1;
				if (page == totalPage)
					break;
			}
			list.add("<a href=" + url + "=" + (i + 1) + ">" + (i + 1) + "</a>");
		}
	}

	/**
	 * 第五页
	 * 
	 * @param page
	 * @param url
	 * @param list
	 */
	private static void fifthPage(int page, String url, List<String> list) {
		for (int i = 0; i < 6; i++) {
			if (i + 1 == page) {
				list.add("<span class='current'>" + page + "</span>");
				i = i + 1;
			}
			list.add("<a href=" + url + "=" + (i + 1) + " rel='next'>"
					+ (i + 1) + "</a>");
		}
	}

	/**
	 * 添加尾部
	 * 
	 * @param totalPage
	 * @param url
	 * @param list
	 */
	private static void addFootPage(int totalPage, String url, List<String> list) {
		list.add(" <span class='gap'>&hellip;</span> ");
		list.add("<a href=" + url + "=" + (totalPage - 1) + ">"
				+ (totalPage - 1) + "</a>");
		list.add("<a href=" + url + "=" + (totalPage) + ">" + (totalPage)
				+ "</a>");
	}

	/**
	 * 添加头
	 * 
	 * @param url
	 * @param list
	 */
	private static void addHeadPage(String url, List<String> list) {
		list.add("<a href=" + url + "=" + (1) + ">" + (1) + "</a>");
		list.add("<a href=" + url + "=" + (2) + ">" + (2) + "</a>");
		list.add(" <span class='gap'>&hellip;</span> ");
	}
}



css


body {
  text-align: left;
  font-family: Arial, sans-serifarial, Verdana, Helvetica;
  font-size: 12px;
  line-height: 1.5;
  color: black;
}
.pagination {
	padding: 5px;
	float: left;
}

.pagination a,.pagination a:link,.pagination a:visited {
	padding: 2px 5px 2px 5px;
	margin: 2px;
	border: 1px solid #aaaadd;
	text-decoration: none;
	color: #006699;
}

.pagination a:hover,.pagination a:active {
	border: 1px solid #006699;
	color: #000;
	text-decoration: none;
}

.pagination span.current {
	padding: 2px 5px 2px 5px;
	margin: 2px;
	border: 1px solid #006699;
	font-weight: bold;
	background-color: #006699;
	color: #FFF;
}

.pagination span.disabled {
	padding: 2px 5px 2px 5px;
	margin: 2px;
	border: 1px solid #eee;
	color: #ddd;
}



html代码


<%
			PageOP p = new PageOP();
				List<String> pages = p.getPageHref(pageobj.getPageCount(), pageobj
						.getNowPage(),"index.jsp?page");
				for(String s:pages){
					out.print(s);
				}
		%>




算法一点都不简洁.请大家帮忙完善,谢谢了
上例子程序

我就不传包了.太慢,一共需要4个包

dbcp的三个.一个数据库连接.一个spring核心包,大家自己添加好了..spring的是2.5.6的





  • 大小: 6.1 KB
  • 大小: 6.6 KB
分享到:
评论

相关推荐

    je-5.0.73-API文档-中文版.zip

    标签:sleepycat、je、中文文档、jar包、java; 使用方法:解压翻译后的API文档,用浏览器打开“index.html”文件,即可纵览文档内容。 人性化翻译,文档中的代码和结构保持不变,注释和说明精准翻译,请放心使用。

    MELSERVO-JE系列样本.pdf

    标签“三菱伺服电机,JE系列”提示我们本样本主要关注的是三菱电机生产的伺服电机,特别是JE系列。 从部分内容可以看出,MELSERVO-JE系列伺服电机控制器具有以下技术特性: 1. 优越的基本性能和先进的易用性:产品...

    je-5.0.73-API文档-中英对照版.zip

    标签:sleepycat、je、中英对照文档、jar包、java; 使用方法:解压翻译后的API文档,用浏览器打开“index.html”文件,即可纵览文档内容。 人性化翻译,文档中的代码和结构保持不变,注释和说明精准翻译,请放心...

    JE分词 1.4+1.5

    "JE分词 1.4+1.5"是一个针对中文文本处理的工具,主要用于将汉字字符串分割成有意义的词语,这是自然语言处理中的关键步骤。这个版本的JE分词在之前的基础上进行了多方面的改进和增强,使得其在处理中文文本时更为...

    je-analysis.jar

    在这个特定的情况下,"je-analysis-1.5.3.jar" 版本可能是某种数据分析或处理工具的实现,因为"je-analysis"标签暗示了它可能与数据分析相关。 在Java世界中,JAR文件的作用非常关键。它们允许开发者将多个类文件...

    丝印HX-JE芯片资料

    标签则列举了该芯片的主要特性,如“升压IC输入2.5v-5v”和“电荷泵升压IC”,明确指出了该芯片的用途以及适用的电压输入范围。 从【部分内容】中我们可以得知: - HU3031B是一款固定输出电压为5V±4%的芯片,工作...

    BerkeleyDB-JE je-6.0.11

    Oracle BerkeleyDB-JE je-6.0.11

    三菱MR-JE-C伺服电机FB功能块(适用Q系列PLC) 流水线项目,16个MR-JE-C电机,为了加快编程速度,特意做的一个F

    三菱MR-JE-C伺服电机FB功能块(适用Q系列PLC) 流水线项目,16个MR-JE-C电机,为了加快编程速度,特意做的一个FB功能块,内部采用局部变量+全局缓冲区的方式进行编程,多次调用不冲突! 适用于Q系列PLC和MR-JE-C的运动...

    Berkeley DB je3.3版

    **Berkeley DB je3.3版详解** Berkeley DB(简称BDB)是Oracle公司提供的一款开源、轻量级、高性能的嵌入式数据库系统。它最初由Sleepycat Software开发,后被Oracle收购。Berkeley DB je是其增强版,专为Java环境...

    三菱伺服MR-JE使用手册

    ### 三菱伺服MR-JE使用手册关键知识点解析 #### 一、概述 三菱伺服MR-JE系列是一款高性能的交流伺服系统,适用于各种自动化控制领域。本手册旨在提供关于该系列产品安装、配置、维护等方面的技术指导,确保用户能够...

    je-analysis-1.5.1

    "je-analysis-1.5.1"是一款专用于中文分词的开源工具,它在中文信息处理领域扮演着重要的角色。这款工具集成了高效的分词算法,为开发者提供了便捷的接口,使得在Java环境中进行文本分析变得更加简单。"JE分词器"是...

    三菱MR-JE-A伺服说明书

    三菱MR-JE-A伺服说明书详细介绍了三菱电机株式会社生产的MR-JE系列伺服放大器的技术参数、功能、安装、操作和安全注意事项,以下是根据提供的信息整理出的知识点。 ### 标题知识点 1. **产品系列定位**:三菱MR-JE...

    je-analysis-1.5.3、lucene-core-2.4.1分词组件

    本文将深入探讨"je-analysis-1.5.3"和"lucene-core-2.4.1"这两个分词组件,以及它们在相关场景中的应用。 首先,让我们了解什么是分词。分词,即词语切分,是自然语言处理(NLP)中的基本任务之一,它的目标是将...

    MR-JE伺服样本

    三菱伺服MELSERVO-JE系列是三菱电机生产的一款高性能的交流伺服系统,它提供了多种伺服电机和伺服放大器型号,适用于广泛的工业应用。在使用MR-JE伺服样本之前,用户应仔细阅读相关使用说明书和技术资料集以确保安全...

    je-analysis-1.5.3

    《深入解析je-analysis-1.5.3:Java Lucene中的中文全文检索与分词组件》 在现代信息处理领域,全文检索与精准的文本分析是至关重要的技术。Je-analysis,作为一款基于Java的开源全文检索框架Lucene的中文分词组件...

    je-5.0.34.tar.gz

    标签 "je-5.0.34.tar.gz" 与标题相同,表明这是唯一标识该软件包的关键信息。在软件开发和维护过程中,正确地标记和追踪不同版本是至关重要的,以便于版本控制、问题跟踪和升级管理。 至于 "je-5.0.34" 这个压缩...

    GX Works3的MR-JE-C的CC-LINK IE Field Basic通信_描述文件

    《GX Works3与MR-JE-C的CC-LINK IE Field Basic通信详解》 在工业自动化领域,GX Works3是一款广泛使用的编程软件,主要用于三菱电机的PLC(可编程逻辑控制器)编程。而MR-JE-C系列伺服驱动器是三菱电机推出的一款...

    MR-JE-C编程要点.pdf

    JE-C伺服控制要点,方便plc对伺服关键寄存器读写

    三菱伺服JE-C通过cclink ie field basic网络控制,轨迹位置模式、轨迹速度模式、原点复位模式的控制

    主要讲解三菱MR-JE-C产品,在配置文件方式控制模式下,通过CC-LINK IE Field Basic通讯,实现伺服原点回归、定位控置、速度控制功能。 一、内容包括:JE-C控制样例程序 +说明、JE-C伺服放大器资料集+轨迹模式篇 ...

Global site tag (gtag.js) - Google Analytics