1.创建标签的处理类ShowSizeTag类文件:
import java.io.IOException;
import javax.servlet.jsp.JspException;
import javax.servlet.jsp.tagext.TagSupport;
public class ShowSizeTag extends TagSupport {
// 记录总数
public int count;
// 当前设置的页面显示记录数
public int delta;
public int getCount() {
return count;
}
public ShowSizeTag() {
}
public void setCount(int count) {
this.count = count;
}
public int getDelta() {
return delta;
}
public void setDelta(int delta) {
this.delta = delta;
}
public int doEndTag() throws JspException {
// StringBuffer中保存待输出的HTML代码
StringBuffer sb = new StringBuffer();
sb.append("<b>共");
sb.append(count);
sb.append("条记录");
sb.append(" 每页显示 ");
// 创建select box
sb.append("<select name='showSize' id='showSize' onchange='saveSize()'></select></b>");
// 执行initShowSize函数
sb.append("<script>initShowSize(document.getElementById('showSize'),");
sb.append(delta);
sb.append(");</script>");
try {
// 向页面输出内容
pageContext.getOut().write(sb.toString());
} catch (IOException e) {
e.printStackTrace();
}
// 表示按照正常的流程继续执行JSP网页
return EVAL_PAGE;
}
// 通常在 doStartTag 里进行逻辑操作,在 doEndTag 里控制输出。
public int doStartTag() throws JspException {
StringBuffer sb = new StringBuffer();
try {
// 向页面输出内容
pageContext.getOut().write(writeJs(sb));
} catch (IOException e) {
e.printStackTrace();
}
// 表示标签体的内容被忽略
return SKIP_BODY;
}
/**
* 输出HTML内容,js函数用于初始化 select box 的option,内容是分页记录数
*
* @author fanyong
*
* @param sb
* StringBuffer.
*
* @return 显示记录数.
*/
private String writeJs(StringBuffer sb) {
sb.append("<script>\n");
// initShowSize函数参数:1.showSize:select box 对象 2.修改前的显示数
sb.append("function initShowSize(showSize,nowValue){\n");
// 下拉框中列表
sb.append("var pageCounts=\"10,30,50,100\";\n");
sb.append("var pageCountsList=pageCounts.split(',');\n");
sb.append("for(var i=0;i<pageCountsList.length;i++){\n");
// 创建一个新的option:new Option('new text','new value');
sb.append("var option=new Option(pageCountsList[i],pageCountsList[i]);\n");
// option的序号。第一个选项对象是options[0],第二个是options[1],以此类推
// select box 对象增加新option
sb.append("showSize.options[showSize.options.length]=option;\n");
// 下拉框显示定格在当前所选值
sb.append("if(pageCountsList[i]==nowValue){\n");
sb.append("option.selected=true;\n");
sb.append("}}}\n");
sb.append("</script>\n");
return sb.toString();
}
}
2.创建标签库描述文件showsize.tld文件
<?xml version="1.0" encoding="GBK"?>
<!DOCTYPE taglib PUBLIC "-//Sun Microsystems, Inc.//DTD JSP Tag Library 1.2//EN" "http://java.sun.com/dtd/web-jsptaglibrary_1_2.dtd">
<taglib>
<tlib-version>1.0</tlib-version>
<jsp-version>1.2</jsp-version>
<short-name>showSizeTag</short-name>
<tag>
<name>showSize</name>
<tag-class>com.pccw.portlet.tag.ShowSizeTag</tag-class>
<body-content>empty</body-content>
<attribute>
<name>count</name>
<required>true</required>
<rtexprvalue>true</rtexprvalue>
</attribute>
<attribute>
<name>delta</name>
<required>true</required>
<rtexprvalue>true</rtexprvalue>
</attribute>
</tag>
</taglib>
3.在web.xml文件中配置元素
<?xml version="1.0"?>
<web-app xmlns="http://java.sun.com/xml/ns/j2ee" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://java.sun.com/xml/ns/j2ee http://java.sun.com/xml/ns/j2ee/web-app_2_4.xsd" version="2.4">
... ... ... ... ...
<jsp-config>
<taglib>
<taglib-uri>/showSize</taglib-uri>
<taglib-location>/WEB-INF/showsize.tld</taglib-location>
</taglib>
</jsp-config>
</web-app>
4.在JSP文件中引人标签库
<%@ taglib uri="/showSize" prefix="pccw" %>
标签使用方法:
1.导入工具类
<%@page import="com.pccw.portlet.util.ShowSizeUtil" %>
ShowSizeUtil类文件:
import javax.portlet.PortletSession;
import javax.portlet.RenderRequest;
public class ShowSizeUtil {
/**
* 得到用户定制的页面显示记录数
*
* @author fanyong
*
* @param ps
* PortletSession.
* @param renderRequest
* RenderRequest.
*
* @return 显示记录数.
*/
public static int getSize(PortletSession ps, RenderRequest renderRequest) {
// PortletSession中得到showSize属性值
int showSize = ps.getAttribute("showSize") == null ? 0 : (Integer) ps
.getAttribute("showSize");
int showSizeTemp = 10;
if (renderRequest.getParameter("showSize") != null
&& ps.getAttribute("showSize") != null) {
showSizeTemp = Integer.parseInt(renderRequest
.getParameter("showSize"));
}
// 首次显示页面PortletSession中没有保存showSize属性,也没有提交showSize参数
// 页面打开后首次修改显示记录数,提交showSize参数,PortletSession中没有保存showSize属性
if (renderRequest.getParameter("showSize") != null) {
// 得到提交的showSize参数
showSizeTemp = Integer.parseInt(renderRequest
.getParameter("showSize"));
// 如果用户当前定制的显示数和PortletSession中保存的showSize属性值不一致,说明用户修改了之前的定制数
if (showSizeTemp != showSize) {
ps.setAttribute("showSize", showSizeTemp);
}
}
// 首次显示页面PortletSession中没有保存showSize属性,默认显示记录数量是10条
return ps.getAttribute("showSize") == null ? 10 : (Integer) ps
.getAttribute("showSize");
}
}
2.导入标签
<%@ taglib uri="/showSize" prefix="pccw" %>
3.最上面加入Session
PortletSession pss=renderRequest.getPortletSession(false);
4.
int delta = ShowSizeUtil.getSize(pss,renderRequest);
5.加入JavaScript方法(实例中使用StrutsPortlet,所以提交参数struts_action)
function saveSize(){
<portlet:namespace/>fm1.method="POST";
<portlet:namespace/>fm1.action='<portlet:actionURL windowState="<%= WindowState.MAXIMIZED.toString() %>">
<portlet:param name="struts_action" value="/ext/processManager/view"/>
</portlet:actionURL>';
<portlet:namespace/>fm1.submit();
}
如果使用JSPPortlet,提交参数:
<portlet:param name="jsp_page" value="/portlet/ext/workbench/workbench.jsp"/>
<portlet:param name="tab1" value="QueryAllProcess"/>
6.加入提交Form
<form action="" name="<portlet:namespace />fm1">
<table width="100%">
<tr>
<td align="left"><b></b></td>
<!-- 自定义标签需要两个属性count,delta -->
<td align="right"><pccw:showSize count="<%=tempList.size()%>" delta="<%=delta%>" /></td>
</tr>
</table>
</form>
说明:
A count 表示一共有多少条数据
B delta 分页与分页的标签对应
分享到:
相关推荐
本网上书店系统是一个基于MVC(Model-View-Controller)设计模式的Web应用程序,它整合了Java的两大核心框架——Struts和Hibernate,以及自定义标签技术,旨在提供一个高效、安全的图书浏览与购买平台。 **1. ...
本文档将详细介绍一个使用Java Server Pages (JSP)技术实现的自定义分页标签——`PagerTag`。该标签允许开发者在不编写冗余代码的情况下轻松地在JSP页面中实现分页功能。 #### 二、标签简介 `PagerTag`是一个自定义...
`index.wxml`中,你需要编写组件的结构,可以使用`<slot>`标签来实现内容插槽,允许父组件向自定义组件传递内容。通过`wx:if`、`wx:else`、`wx:for`等指令,可以实现条件渲染和循环渲染。 `index.wxss`中,你可以为...
总结来说,`java分页——taglib`是利用自定义标签库来简化Java Web应用中分页功能的实现。通过`pagerdemo`,开发者可以方便地在JSP页面中插入分页组件,并在后端处理分页逻辑,从而提高代码的复用性和可维护性。这个...
根据提供的压缩包文件名“jsp自定义标签——分页标签 - Free Coding - ITeye技术网站_files”,我们可以推断内容可能涉及自定义JSP分页标签的实现。通常,自定义标签的流程如下: 1. **创建Tag类**:继承`javax....
为了实现自定义查询界面的功能,本方案设计了四个核心表来管理查询界面的配置信息: 1. **Table1: FormConfigSettings** —— 界面基础配置表; 2. **Table2: FormChildrenConfigSettings** —— 查询条件详细配置...
3.1 更改与显示文字标签——TextView标签的使用 3.2 更改手机窗口画面底色——drawable定义颜色常数的方法 3.3 更改TextView文字颜色——引用Drawable颜色常数及背景色 3.4 置换TextView文字——CharSequence数据...
3.1 更改与显示文字标签——TextView标签的使用 3.2 更改手机窗口画面底色——drawable定义颜色常数的方法 3.3 更改TextView文字颜色——引用Drawable颜色常数及背景色 3.4 置换TextView文字——CharSequence数据...
拦截器是Struts2的一大特色,它们在Action调用前后执行,可以实现日志记录、权限检查、事务管理等通用功能,极大地提高了代码复用性和可维护性。 **5. OGNL(Object-Graph Navigation Language)** OGNL是Struts2中...
3.1 更改与显示文字标签——TextView标签的使用 3.2 更改手机窗口画面底色——drawable定义颜色常数的方法 3.3 更改TextView文字颜色——引用Drawable颜色常数及背景色 3.4 置换TextView文字——CharSequence数据...
JSP页面通常包含HTML标记和嵌入式的Java脚本元素,如JSP指令、脚本let、表达式、声明、以及自定义标签等。 系统的核心功能包括: 1. **用户管理**:管理员可以添加、删除和修改用户信息,分配权限,确保数据安全和...
本教程将详细讲解如何使用Vue.js来创建一个简单的多标签页系统,并提供了一个实际项目模板——`vue-mutitab-master`作为参考。 首先,Vue.js是一个轻量级的前端JavaScript框架,以其组件化、声明式编程和响应式数据...
JSP的核心概念包括:脚本元素、指令元素、动作元素以及自定义标签。在这个交友网站中,JSP用于处理用户请求,生成动态响应,如用户登录、注册、查看个人信息等。 ### 2. MVC设计模式 为了实现清晰的代码结构和良好...
6. JSP自定义标签:JSP自定义标签允许开发者创建可重用的UI组件,提高代码的可读性和可维护性。TLD(Tag Library Descriptor)文件用于定义自定义标签的属性和行为。 7. CSS和JavaScript:前端界面的美化和交互通常...
3.1 更改与显示文字标签——TextView标签的使用 3.2 更改手机窗口画面底色——drawable定义颜色常数的方法 3.3 更改TextView文字颜色——引用Drawable颜色常数及背景色 3.4 置换TextView文字——CharSequence数据...
) 2.3 Android应用程序架构——从此开始 2.4 可视化的界面开发工具 2.5 部署应用程序到Android手机 第3章 用户人机界面 3.1 更改与显示文字标签——TextView标签的使用 3.2 更改手机窗口画面底色——drawable定义...
3.1 更改与显示文字标签——TextView标签的使用 3.2 更改手机窗口画面底色——drawable定义颜色常数的方法 3.3 更改TextView文字颜色——引用Drawable颜色常数及背景色 3.4 置换TextView文字——CharSequence数据...