- 浏览: 262435 次
- 性别:
- 来自: 北京
文章分类
最新评论
-
591945028:
[b][b][b][b][b][b][/b][/b][/b][ ...
spring事务 -
Gozs_cs_dn:
根据你的配置, 注解事务似乎无效呢?
spring事务 -
lianchun_zheng:
...
ajax读取json数据 -
yueliancao:
真好 高手
源码编译安装mysql(适用于5.5全部版本) -
jyjava:
Castor,Jaxb,xbean,xStream
spring jdbctemplate 实体属性映射值为null
这几天一直在看je的分页显示觉得做的非常不错.很合理人性化.于是乎自己也想搞个.网上找了找.貌似je用的是displaytag组件实现的..自己实在是懒.没去看.从网上找了段代码,然后修修补补改成如下格式
不过没有je做的好.有些地方没多想.请大家完善(这里的css是借用je的..robbin老大多包涵)
然后发算法类
css
html代码
算法一点都不简洁.请大家帮忙完善,谢谢了
上例子程序
我就不传包了.太慢,一共需要4个包
dbcp的三个.一个数据库连接.一个spring核心包,大家自己添加好了..spring的是2.5.6的
不过没有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'>« 上一页</a> "); } else { list.add("<span class='disabled prev_page'>« 上一页</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'>下一页 »</a>"); } else { list.add(" <span class='disabled next_page'>下一页 »</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'>…</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'>…</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的
发表评论
-
spring jdbctemplate 实体属性映射值为null
2009-12-17 23:50 11996今天在做mysql和derby数 ... -
ajoo经典文章.你擦了吗
2009-12-16 22:39 1724这是从百度找到的.原文已经被删除了..悲剧.可惜那么多 ... -
给C++初学者的忠告
2009-10-27 20:41 1198原文:http://love21keai.iteye.com/ ... -
第一次出现java bug
2009-10-27 16:18 1688用了2年多java了.还是第一次出现直接崩溃的系统bug. ... -
jdk1.5增强的for循环
2009-08-20 00:07 3736jkd1.5提供了对for循环的加强。在特定的场合很大的简化了 ... -
java反射浅析
2009-08-19 23:59 1251在Java运行时环境中,对于任意一个类,能否知道这个类有哪些属 ... -
==和eauals的区别
2009-08-18 20:36 1994一直对==和equals方法判断相等很模糊。今天又仔细看了下。 ... -
怎么重构
2009-07-22 22:22 1253今天下定决心弄明白je的分页.捣鼓了快一个小时才弄明白规律. ... -
两种转码方式的区别
2009-07-18 11:58 1849这是张孝祥老师的java就业培训视频教程里面的一道题目(有所变 ... -
java自动装箱拆箱
2009-07-02 19:27 1914java的自动置入和取出对原生类型进行了自动转换 看如下代码 ... -
泛型(Generics)简说
2009-07-02 15:14 2424泛型是JDK1.5中一个最重要的特征。通过引入泛型,我们将获得 ... -
MD5加密类
2009-05-20 16:45 64package com.qihang.street.utils ... -
JDBC
2009-04-23 17:18 152本帖已被删除 -
java控制字符不能输入特殊字符和空格
2009-02-25 16:37 692import java.util.regex.Patter ... -
Javamail操作指南
2009-03-19 13:14 126import java.util.*; import jav ... -
Java实现给图片添加水印
2009-03-19 13:18 1368import java.awt.*; import j ... -
java读取远程url图片,得到宽高
2009-03-27 16:04 12848import java.awt.image.BufferedI ...
相关推荐
标签:sleepycat、je、中文文档、jar包、java; 使用方法:解压翻译后的API文档,用浏览器打开“index.html”文件,即可纵览文档内容。 人性化翻译,文档中的代码和结构保持不变,注释和说明精准翻译,请放心使用。
标签“三菱伺服电机,JE系列”提示我们本样本主要关注的是三菱电机生产的伺服电机,特别是JE系列。 从部分内容可以看出,MELSERVO-JE系列伺服电机控制器具有以下技术特性: 1. 优越的基本性能和先进的易用性:产品...
标签:sleepycat、je、中英对照文档、jar包、java; 使用方法:解压翻译后的API文档,用浏览器打开“index.html”文件,即可纵览文档内容。 人性化翻译,文档中的代码和结构保持不变,注释和说明精准翻译,请放心...
"JE分词 1.4+1.5"是一个针对中文文本处理的工具,主要用于将汉字字符串分割成有意义的词语,这是自然语言处理中的关键步骤。这个版本的JE分词在之前的基础上进行了多方面的改进和增强,使得其在处理中文文本时更为...
在这个特定的情况下,"je-analysis-1.5.3.jar" 版本可能是某种数据分析或处理工具的实现,因为"je-analysis"标签暗示了它可能与数据分析相关。 在Java世界中,JAR文件的作用非常关键。它们允许开发者将多个类文件...
标签则列举了该芯片的主要特性,如“升压IC输入2.5v-5v”和“电荷泵升压IC”,明确指出了该芯片的用途以及适用的电压输入范围。 从【部分内容】中我们可以得知: - HU3031B是一款固定输出电压为5V±4%的芯片,工作...
Oracle BerkeleyDB-JE je-6.0.11
三菱MR-JE-C伺服电机FB功能块(适用Q系列PLC) 流水线项目,16个MR-JE-C电机,为了加快编程速度,特意做的一个FB功能块,内部采用局部变量+全局缓冲区的方式进行编程,多次调用不冲突! 适用于Q系列PLC和MR-JE-C的运动...
**Berkeley DB je3.3版详解** Berkeley DB(简称BDB)是Oracle公司提供的一款开源、轻量级、高性能的嵌入式数据库系统。它最初由Sleepycat Software开发,后被Oracle收购。Berkeley DB je是其增强版,专为Java环境...
### 三菱伺服MR-JE使用手册关键知识点解析 #### 一、概述 三菱伺服MR-JE系列是一款高性能的交流伺服系统,适用于各种自动化控制领域。本手册旨在提供关于该系列产品安装、配置、维护等方面的技术指导,确保用户能够...
"je-analysis-1.5.1"是一款专用于中文分词的开源工具,它在中文信息处理领域扮演着重要的角色。这款工具集成了高效的分词算法,为开发者提供了便捷的接口,使得在Java环境中进行文本分析变得更加简单。"JE分词器"是...
三菱MR-JE-A伺服说明书详细介绍了三菱电机株式会社生产的MR-JE系列伺服放大器的技术参数、功能、安装、操作和安全注意事项,以下是根据提供的信息整理出的知识点。 ### 标题知识点 1. **产品系列定位**:三菱MR-JE...
本文将深入探讨"je-analysis-1.5.3"和"lucene-core-2.4.1"这两个分词组件,以及它们在相关场景中的应用。 首先,让我们了解什么是分词。分词,即词语切分,是自然语言处理(NLP)中的基本任务之一,它的目标是将...
三菱伺服MELSERVO-JE系列是三菱电机生产的一款高性能的交流伺服系统,它提供了多种伺服电机和伺服放大器型号,适用于广泛的工业应用。在使用MR-JE伺服样本之前,用户应仔细阅读相关使用说明书和技术资料集以确保安全...
《深入解析je-analysis-1.5.3:Java Lucene中的中文全文检索与分词组件》 在现代信息处理领域,全文检索与精准的文本分析是至关重要的技术。Je-analysis,作为一款基于Java的开源全文检索框架Lucene的中文分词组件...
标签 "je-5.0.34.tar.gz" 与标题相同,表明这是唯一标识该软件包的关键信息。在软件开发和维护过程中,正确地标记和追踪不同版本是至关重要的,以便于版本控制、问题跟踪和升级管理。 至于 "je-5.0.34" 这个压缩...
《GX Works3与MR-JE-C的CC-LINK IE Field Basic通信详解》 在工业自动化领域,GX Works3是一款广泛使用的编程软件,主要用于三菱电机的PLC(可编程逻辑控制器)编程。而MR-JE-C系列伺服驱动器是三菱电机推出的一款...
JE-C伺服控制要点,方便plc对伺服关键寄存器读写
主要讲解三菱MR-JE-C产品,在配置文件方式控制模式下,通过CC-LINK IE Field Basic通讯,实现伺服原点回归、定位控置、速度控制功能。 一、内容包括:JE-C控制样例程序 +说明、JE-C伺服放大器资料集+轨迹模式篇 ...