使用的时候像这样:
<form action="<%=request.getContextPath();%>/pageAction.do" name ="hello" method="post" >
<test:pager formName="hello"/>
</form>
form的action名字随便写,只要给tag传进formname就可以了。
不过组装显示内容的action里要根据从页面得到的(pageIndex/pageTotal/pageNo)来组装内容列表。
------------------------------------------------------------------------------
等写完整了把完整的放上来,待续......
/*
* Created on 2004-8-6
* author:xmx
*/
package demo.pagetag;
public class PageInfo {
private int _recordTotal;
private int _pageTotal;
private int _currentPage;
private int _pageSize;
/**
* @return
*/
public int getRecordTotal(); {
return _recordTotal;
}
/**
* @param i
*/
public void setRecordTotal(int i); {
_recordTotal = i;
}
/**
* @return
*/
public int getCurrentPage(); {
return _currentPage;
}
/**
* @return
*/
public int getPageTotal(); {
int tmp=_recordTotal/_pageSize;
_pageTotal=(_recordTotal%_pageSize==0);?tmp:tmp+1;
return _pageTotal;
}
/**
* @param i
*/
public void setCurrentPage(int i); {
_currentPage = i;
}
/**
* @param i
*/
public void setPageTotal(int i); {
_pageTotal = i;
}
/**
* @return
*/
public int getPageSize(); {
return _pageSize;
}
/**
* @param i
*/
public void setPageSize(int i); {
_pageSize = i;
}
/**
* 返回当前页起始记录
* @return
*/
public int getStartRecord(); {
if (_pageTotal == 0); {
return 0;
} else {
return (_currentPage - 1); * _pageSize + 1;
}
}
/**
* 返回当前页结尾记录
* @return
*/
public int getEndRecord(); {
if (_pageTotal == 0); {
return 0;
} else if (_pageTotal == _currentPage);{
return _recordTotal;
} else {
return _currentPage * _pageSize ;
}
}
}
/*
* Created on 2004-8-6
* author:xmx
*/
package demo.pagetag;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.jsp.JspException;
import javax.servlet.jsp.tagext.TagSupport;
import org.apache.struts.util.RequestUtils;
import org.apache.struts.util.ResponseUtils;
public class PageTag extends TagSupport {
protected String name =null;
protected String formName = null;
public String getName(); {
return name;
}
public void setName(String name); {
this.name = name;
}
public String getFormName(); {
return formName;
}
public void setFormName(String formName); {
this.formName = formName;
}
/* (non-Javadoc);
* @see javax.servlet.jsp.tagext.Tag#doStartTag();
*/
public int doStartTag(); throws JspException {
String pageName = name;
if (name==null || name.trim();.equals("");); {
pageName = "pageName";
}
PageInfo pInfo = (PageInfo);RequestUtils.lookup(pageContext, pageName, "request");;
String imagePath = ((HttpServletRequest);pageContext.getRequest(););.getContextPath();;
System.out.println("============== Page tag start ===========");;
System.out.println("FormName = "+formName.trim(););;
System.out.println("============== Page tag end ===========");;
System.out.println();;
if (pInfo == null);{
System.out.println("pInfo is null ");;
return SKIP_BODY;
}else{
System.out.println("pInfo.currentPage = "+pInfo.getCurrentPage(););;
}
StringBuffer sb = new StringBuffer();;
createNavigateBar(sb,pInfo,imagePath);;
createJSFunction(sb);;
sb=sb.append("<font size=\"30\" color='red'>hello,小南</font>");;
ResponseUtils.write(pageContext,sb.toString(););;
return (SKIP_BODY);;
}
private void createJSFunction(StringBuffer sb); {
String actionFormName = formName.trim();; //设置Form的名称
sb.append("<script language=\"JavaScript\">\n");;
sb.append("function goPage(pageIndex); {\n");;
sb.append(actionFormName + ".target=\"_self\";\n");;
sb.append(actionFormName + ".pageIndex.value=pageIndex;\n");;
sb.append(actionFormName + ".submit();;\n");;
sb.append("}\n");;
sb.append("function goToPage(); {\n");;
sb.append("var page=" + actionFormName + ".pageNo.value;\n");;
sb.append("if (new Number(page);.toString();==\"NaN\");{\n");;
sb.append("alert(\"请输入 数 字\");;\n");;
sb.append("return;\n");;
sb.append("}else if(page==\"\"||page==null); {\n");;
sb.append("alert(\"请输入 数 字\");;\n");;
sb.append("return;\n");;
sb.append("}\n");;
sb.append("var pageAmount=" + actionFormName + ".pageTotal.value;\n");;
sb.append("if (parseInt(page);>parseInt(pageAmount);); {\n");;
sb.append("page=pageAmount;\n");;
sb.append("}else if (parseInt(page);<1); {\n");;
sb.append("page=1;\n");;
sb.append("}\n");;
sb.append("goPage(page);;\n");;
sb.append("}\n");;
sb.append("</script>\n");;
}
private void createNavigateBar(StringBuffer sb,PageInfo pInfo,String imagePath); {
int currentPage = pInfo.getCurrentPage();;
int pageTotal = pInfo.getPageTotal();;
sb.append("<input type=\"hidden\" name=\"pageIndex\" value=\"" + currentPage + "\">");.append("\n");;
sb.append("<input type=\"hidden\" name=\"pageTotal\" value=\"" + pageTotal + "\">");.append("\n");;
sb.append("<table width=\"100%\" border=\"0\"><tbody><tr>");.append("\n");;
sb.append("<td width=\"20%\" height=\"30\" align=\"center\">第" + currentPage + "页</td>");.append("\n");;
sb.append("<td width=\"15%\" align=\"center\">共" + pageTotal + "页</td>");.append("\n");;
sb.append("<td width=\"15%\" align=\"center\">共" +pInfo.getRecordTotal(); + "条</td>");.append("\n");;
sb.append("<td width=\"50%\" valign=\"center\">");.append("\n");;
sb.append("<a href=\"javascript:goPage(1);;\" style=\"cursor:hand\">首页| </a>");.append("\n");;
int prevPage = 1;
if (currentPage>=2); {
prevPage = currentPage -1;
}
sb.append("<a href=\"javascript:goPage(" + prevPage + ");;\" name=\"page\" style=\"cursor:hand\">前一页| </a>");.append("\n");;
int nextPage = pageTotal;
if (currentPage<pageTotal-1); {
nextPage = currentPage +1;
}
sb.append("<a href=\"javascript:goPage(" + nextPage + ");;\" style=\"cursor:hand\">后一页| </a>");.append("\n");;
int lastPage = pageTotal;
if (pageTotal<2); {
lastPage = 1;
}
sb.append("<a href=\"javascript:goPage(" + lastPage + ");;\" style=\"cursor:hand\">末页| </a>");.append("\n");;
sb.append("转到第<input name=\"pageNo\" type=\"text\" class=\"Input\" size=\"5\">页");.append("\n");;
sb.append("<a href=\"javascript:goToPage();;\" style=\"cursor:hand\">Go</a>");.append("\n");;
sb.append("</td></tr></tbody></table>");.append("\n");;
}
}
在action里使用的时候例子如下:
package demo.action;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import org.apache.struts.action.Action;
import org.apache.struts.action.ActionForm;
import org.apache.struts.action.ActionForward;
import org.apache.struts.action.ActionMapping;
import demo.pagetag.PageInfo;
public class ShowPageInfoAction extends Action {
// --------------------------------------------------------- Instance Variables
// --------------------------------------------------------- Methods
/**
* Method execute
* @param ActionMapping mapping
* @param ActionForm form
* @param HttpServletRequest request
* @param HttpServletResponse response
* @return ActionForward
* @throws Exception
*/
public ActionForward execute(
ActionMapping mapping,
ActionForm form,
HttpServletRequest request,
HttpServletResponse response);
throws Exception {
System.out.println("ShowPageInfoAction .......");;
//tag 里用到,必须
PageInfo pInfo = new PageInfo();;
pInfo.setPageSize(10);; //recordsNumber/Page
pInfo.setRecordTotal(101);; //到service里拿
setPageInfo(request, pInfo);;
//查询,取到记录
//List list=service.find(pInfo.getStartRecord();,pInfo.getEndRecord(););;
//or
//List list=service.find(pInfo);;
//request.setAttribute("fileList",list);;
return mapping.findForward("success");;
}
private void setPageInfo(HttpServletRequest request, PageInfo pInfo); {
String pageIndex = request.getParameter("pageIndex");;//从页面取到的当前页
if (pageIndex == null || pageIndex.equals("");); {
pInfo.setCurrentPage(1);;
} else {
pInfo.setCurrentPage(Integer.parseInt(pageIndex););;
}
String pageNo = request.getParameter("pageNo");;//跳转的目的页index
if (pageNo != null && !pageNo.equals("");); {
pInfo.setCurrentPage(Integer.parseInt(pageNo););;
}
request.setAttribute("pageName", pInfo);;//tag需要的PageInfo信息
}
}
分享到:
相关推荐
本文将深入探讨如何在QTableView中实现表格翻页标签,同时确保表格可以精确定位,支持拖动调整大小,并能与滑动条联动。 首先,我们需要了解QTableView的基本使用。QTableView是一个视图类,它继承自...
1、增加短信息互发功能,用户与用户互发...7、增加新闻上一页翻页标签,新闻下一页翻页标签 8、增加产品上一页翻页标签,产品下一页翻页标签 9、增加新闻内容标签解释,扩展内容标签解析 10、增加前台在线订购商品功能
在这个例子中,“j2ee翻页自定义标签+sturts”着重展示了如何在J2EE环境中实现分页功能,同时对比了使用自定义标签和Struts框架内置标签的方法。 首先,让我们深入了解分页功能。在大数据量的展示场景中,分页是必...
- **翻页标签**:`{dede:pagebreak}`, 在长篇文章中插入分页符。 ### 9. 功能按钮标签 - **收藏、推荐、反馈与打印按钮**:通过 `{dede:fieldname='phpurl'}` 结合不同的PHP脚本,可以实现收藏、推荐、反馈等功能...
在本项目中,“extjs实现的带标签、翻页动画的书”显然利用了ExtJS的组件化特性和动画功能,创建了一个模拟真实书籍阅读体验的应用。 首先,我们来看看“标签”这一概念。在Web应用中,标签(Tab)通常用来组织和...
在这个翻页控件中,`pager.tld`定义了一个名为`pager`的标签,用于在页面上渲染翻页组件。开发者可以在JSP页面中通过`<pager:tagname>`的形式调用这个标签,从而快速插入翻页组件。 接着,`Faces-config.txt`文件...
在HTML中,我们通常使用`<img>`标签来插入图片。它的基本语法如下: ```html 替代文本" width="宽度" height="高度"> ``` `src`属性指定了图片的路径,`alt`提供了图片无法显示时的替代文本,而`width`和`height`...
在本例中,HTML文件包含了一系列的标签,这些标签定义了页面的各个部分,如标题、段落、图像等。 2. **CSS样式**: 虽然描述中没有明确提到CSS,但为了实现黑色翻页时钟的样式,开发者必定使用了CSS(Cascading ...
通过标签“字数翻页”、“字符翻页”和“按字数翻页”,我们可以推断出这个压缩包主要是针对按字数划分页面内容的JavaScript实现。而“翻页”标签则暗示了这是一个关于分页的技术,只是这里的分页标准是基于字符或...
这种技术在微信H5页面中尤其常见,因为它们可以提供类似图书翻页的动态体验,使得内容展示更加生动有趣,增强用户的浏览兴趣。接下来,我们将深入探讨这个话题,包括HTML5在移动端的优势、实现翻页效果的关键技术和...
在这个项目中,翻页标签可以隐藏,意味着在特定情况下,如数据较少时,可以选择不显示分页,提高界面简洁性。 3. **查询请求优化**:描述中提到“修改查询请求2次后台”,这可能是为了减少不必要的网络请求和提高...
【标签】"JS"指示了这个项目的核心技术是JavaScript,这是一种广泛应用于Web开发的脚本语言,负责在客户端执行,提供动态交互和实时更新的功能。在这里,JavaScript被用来实现图片翻页的交互逻辑和动画效果。 ...
标签“翻页android”进一步明确了这个项目是关于Android平台上的翻页动画技术。在Android开发中,实现这样的效果可能需要用到自定义View或者动画库,比如使用Canvas进行绘图,或者利用Android提供的Animation API。 ...
结合给出的标签"Jquery 图片 翻页 超炫 特效",我们可以进一步优化这个基本方案,比如加入更多的动画效果,如3D翻转、淡入淡出组合、滑动切换等,以增强视觉冲击力。还可以利用CSS3的过渡和动画属性,与jQuery结合,...
我们需要找到页面中存放图片的元素,如`<img>`标签,然后通过JavaScript去修改其`src`属性,实现图片的切换。可以使用`document.getElementById`、`querySelector`或`querySelectorAll`等方法获取元素,再通过`.src`...
21、增加栏目翻页标签 22、修正文章删除后TAG相关文章数量统计问题; 23、修正敏感词控制无效的问题 24、修正发布多媒体视频文件无效的问题; 25、新增管理员管理的细微权限验证,低级别管理员不能管理高级别管理员...
创建一个包含小时、分钟和秒的结构,每个部分可以由多个数字组成,比如 `<span>` 标签表示单个数字: ```html <div class="clock-part hours"></div> <div class="clock-part minutes"></div> ...
在标签中,“css”表示这个资源与CSS技术紧密相关,“翻页”则强调了这些代码是用于实现页面翻转效果的。这些标签有助于人们快速识别和搜索到相关的学习材料或解决方案。 根据压缩包的文件名“24款纯css翻页代码”...
在制作翻页效果时,我们通常会使用`<div>`标签来创建翻页的容器,并利用CSS(层叠样式表)来定义其样式和布局。 在HTML代码中,我们可以创建两个或多个`<div>`,每个代表一页内容。例如: ```html 这是第一页的...
在Android平台上开发一款书籍翻页效果的TXT阅读器是一项具有挑战性的任务,它涉及到许多关键技术点,包括文本处理、UI设计、动画效果以及性能优化。本文将深入探讨如何实现这样的应用,主要关注以下几个方面: 1. *...