`

ECSide入门(资料整理)

阅读更多
ECSide是有一个基于jsp tag的开源列表组件.简单的说,它就是一组可以帮助你快速实现强大的列表的jsp标签.
  它的工作原理很简单.将您将要展现的列表的数据集合(Collection),放入request/pagecontext/session内(使用setAttribute方法.这个工作可以在action/servlet里完成,也可以在jsp页面内完成),然后页面跳转到使用ECSide标签的jsp页面,此时ECSide就可以帮助您展现出所需要的列表.
一个简单的流程通常是这样的.

1 客户端请求action/servlet(如 http://10.195.129.101/test/userlist.do)
2 action接受到请求后,调用相应的BO/dao,执行取列表数据的方法.
3 取得数据后(通常是一个vo/map的list),将数据放入request内(使用requset.setAttribute(key,value)方法.)
4 将请求forward到使用ECSide标签的jsp页面.
5 ECSide将展现出列表.
  知道了原理,那么让我们一起来完成一个快速而简单的例子吧.现在有一张用户信息表,如下

表名称: USER_INFO(用户信息表)
字段:
    USERID   (用户编号)
    USERNAME (用户名)
    PASSWD   (密码)
    USERROLE (角色) 0 被锁定  1 普通  2 高级 3 管理员 4超级管理员
    REGDATE  (注册日期)
    EMAIL    (EMAIL)
    GENDER   (性别) 0 未知 1 男 2女
    MEMO     (备注)

h2db的建表脚本如下:

create table USER_INFO (
    USERID int not null identity,
    USERNAME varchar(80) not null,
    PASSWD varchar(255) not null,
    USERROLE varchar(10) default 1,
    REGDATE varchar(20) ,
    EMAIL varchar(128) ,
    GENDER varchar(2) default 0,
    MEMO varchar(1024)  ,
    constraint PK_USER_INFO primary key (USERID)
);
对应VO:

public class UserInfo {
private Integer userId;
private String userName;
private String passwd;
private String userRole;
private String regDate;
private String email;
private String gender;
private String memo;

/* 略去getter setter方法 */

}
  对应DAO如下(假设DAO里只有一个方法,取得全部的用户信息,返回的是VO的List):

public class UserDAO extends BaseDAO  {

public List getAllUsers(){
  StringBuffer bufSql = new StringBuffer("SELECT * FROM USER_INFO WHERE 1=1");
 
  Connection conn=null;
  PreparedStatement pstmt = null;
  ResultSet rest = null;

  List allUsers=null;

  try {
   conn = getConnection();
   pstmt = ConnectionUtils.prepareStatement(conn,bufSql.toString());
   rest = pstmt.executeQuery();
   allUsers=new ArrayList();
   UserVO userVO=null;
   while (rest.next()) {
    userVO=new UserVO();
    /* 略去将ResultSet结果放入VO的过程 */
    allUsers.add(userVO);
   }
  } catch (Exception e) {
   allUsers=null;
  }finally{
   close(rest, pstmt, conn);
  } 
  return allUsers;
}

}


该简单例子假设该表数据量不大:500以内,采用ECSide的java内存分页技术

由于此例子实在简单,所以略去BO层.

action(DispatchActionSupport)代码如下:


public class MyTestAction extends DispatchAction {

// java内存分页
public ActionForward getAllUsers(ActionMapping mapping, ActionForm form,
HttpServletRequest request, HttpServletResponse response)
throws Exception {

  // 取得DAO,这里是从spring上下文中取得指定DAO,略去spring相关代码
  UserDAO userDAO=(UserDAO)getBean("userDAO");

  List allUsers = userDAO.getAllUsers();

//将结果集合放入request内,记住键名"allUsers".
  request.setAttribute("allUsers", allUsers);


  //forward到列表展现页面
  return mapping.findForward("userlistPage");

}
}



访问该action的URL为
http://localhost:8080/ecsdemo/simpledemo.do?actionMethod=getAllUsers

jsp页面:
引入标签声明

<%@ taglib uri="http://www.ecside.org" prefix="ec" %>


通常jsp页面内取得应用上下文是必须的.

<%
String webapp=request.getContextPath();
%>


引入ECSide必要的css js

<link rel="stylesheet" type="text/css" href="<%=webapp%>/common/css/ECSide_style.css" />
<script type="text/javascript" src="<%=webapp%>/common/js/prototype_mini.js" ></script>
<script type="text/javascript" src="<%=webapp%>/common/js/ECSide.js" ></script>


ECSide的标签,也是展现列表最关键的环节:


<ec:table items="allUsers" var="user"
retrieveRowsCallback="process"
action="${pageContext.request.contextPath}/simpledemo.do?actionMethod=getAllUsers"
title="用户列表"

width="100%"
classic="true"
>
<ec:row>
<ec:column width="50" property="_0" title="序号" value="${GLOBALROWCOUNT}" />
<ec:column width="80" property="userRole" title="角色"   />
<ec:column     property="userName" title="用户名" />
<ec:column width="100" property="passwd" title="密码"  />
<ec:column width="120" property="email" title="电子信箱" />
<ec:column width="70" property="gender" title="性别"  />
</ec:row>
</ec:table>


  <ec:table> ECSide的主标签,可以理解为 html里的table标签,items指明列表集合在request的属性表里的键名, var指明迭代列表集合时,单条记录所用的变量名.此处类似jstl里的c:forEach标签.
retrieveRowsCallback="process"  指明采用ECSide的java内存分页技术.action指明翻页排序等操作时,所要调用的action的url,在这里你可以继续使用展现列表所使用的action
title="用户列表"  列表的标题
width="100%"  列表的宽度
classic="true"  使用传统方式列表

<ec:row> 行标签,可以理解为类似html里的tr标签

<ec:column> 列标签,可以理解为类似html里的td标签

width列的宽度, 类似td的 width属性

property 该列所要显示的数据在VO中对应的属性字段的名字(如果每条数据是存放在VO里的话),或MAP里对应的key的名字(如果每条数据是存放在MAP里的话)
title 表头中该列所要显示的名称
value 该列所要显示的内容.当你要显示的内容默认不是VO/MAP里的值的时候,你才需要使用value属性,为该列手动的指定一个值.
${GLOBALROWCOUNT}为ECSide内置的一个特殊变量,表示的数据所在的行号,针对全部数据而言,${ROWCOUNT}是针对当前页面而言.

分享到:
评论

相关推荐

    ecside入门者必看

    ### ECSide入门者必看:理解与应用 #### 一、ECSide简介与核心功能 ECSide作为一款优秀的开源列表组件,在Web程序开发中扮演着至关重要的角色。其设计初衷是为了提供一种高效、灵活的方式来展示数据列表,并支持...

    ECSIDE入门例子

    通过这个入门例子,学习者可以掌握ECSIDE的基本操作,理解如何利用ECSIDE进行云服务的开发和管理,为实际的项目开发打下基础。实践中,应按照教程步骤,逐步熟悉每个功能,并尝试自己创建和部署简单的应用,以加深...

    ECSide入门

    ### ECSide入门详解 #### 一、ECSide概述 ECSide是一个基于JSP Tag的开源列表组件,它的主要功能在于提供了一组强大的标签库,帮助开发者快速地在Web应用中实现各种列表展示功能。与传统的JSP编程相比,ECSide提供...

    ecside

    `ecside` 是一个基于 Java 的命令行工具,用于快速开发和管理 Web 应用程序。它集成了诸如代码生成、数据库操作、模板引擎等功能,旨在提高开发效率,减少重复工作,使得开发者可以更加专注于业务逻辑的实现。 在...

    Ecside学习资料(包括架包和相应的参考技术文档)

    5. **集成开发环境(IDE)支持**:虽然没有明确提及,但学习资料可能还包括了如何在像Eclipse、IntelliJ IDEA这样的IDE中配置和使用Ecside的指导,这对于提高开发效率至关重要。 6. **数据库集成**:Ecside通常会...

    Ecside2.0中文教程

    EcSide2.0是一款基于Java开发的Web应用框架,它主要致力于简化Web应用程序的开发流程,提高开发效率。本教程将全面介绍如何使用EcSide2.0进行开发,特别是对于那些不熟悉Java Web或者对MVC(Model-View-Controller)...

    ECSide文档.pdf

    《ECSide:一个强大的JSP列表组件》 ECSide,全称为Extreme Components Side,是一个开源的JSP列表组件,源于eXtremeComponents项目,但已独立发展并拥有自己的特色。这个组件专注于提供列表的显示功能,同时支持单...

    ecside源码

    **ecSide 源码分析** ecSide 是一个基于 JavaScript 的客户端应用框架,主要用于构建富互联网应用程序(Rich Internet Applications,RIA)。它强调组件化开发,提供了丰富的组件库和灵活的事件处理机制,使得...

    ecside2.0最新版本

    标题“ecside2.0最新版本”与描述“ecside2.0 2007年10月28日最新修正版”共同指向一个特定的软件更新,即ecside的2.0版本,它在2007年10月28日进行了最后一次修订。ecSide是一款基于Java的Web应用框架,专为构建...

    ecside 文 档

    【Ecside技术详解】 Ecside是一款基于JSP标签的开源列表组件,它提供了一组JSP标签,能够帮助开发者快速构建功能强大的列表展示。Ecside的核心思想是简化数据集合(如Collection)到页面展示的过程,通过将数据放入...

    分页组件ECSIDE文档

    ### 分页组件ECSIDE文档知识点详述 #### 一、ECSIDE组件概述与功能实现 **ECSIDE**,作为一款专为Web应用程序设计的分页组件,其核心功能在于提供高效、灵活的数据展示解决方案。该组件源于**eXtremeComponents**...

    Ecside中文教程

    Ecside,全称为Eclipse Console for Side Effects,是一款专为Java开发者设计的开源列表组件。它主要用于增强Eclipse IDE中的控制台输出,特别是在处理大量数据时,提供更有效的浏览和管理方式。Ecside通过在Eclipse...

    ecside介绍:

    **ecside介绍** ecside,全称为"Eclipse Console for SQL and DDL Editor",是一款基于Eclipse平台的数据库管理工具。它专为数据库查询、数据编辑以及DDL(Data Definition Language)操作提供了一个集成的开发环境...

    ecside的中文文档,和实例讲解,和所需类包2.0的

    1. **快速入门**:文档中会介绍如何安装配置ECSide,以及创建第一个项目的基本步骤,帮助初学者快速上手。 2. **概念理解**:文档深入解释了ECSide的关键概念,如控制器、模型、视图等,帮助开发者建立清晰的概念...

    ecside 文档(很详细)

    ### ECSide 文档详解 #### 一、项目概述与组件介绍 ##### 1.1 项目模块组成 该项目集成了ECSide(一种用于JSP的列表组件),以实现列表展示及对单一表格数据的基本操作——增加、删除、修改与查询。ECSide作为一...

    ecside2.0RC1项目包

    ecside2.0RC1项目包,引入即可运行,无需额外的jar包。 ECSide是有一个基于jsp tag的开源列表组件. 简单的说,它就是一组可以帮助你快速实现强大的列表的jsp标签. 它的工作原理很简单. 您将要展现的列表的数据集合...

    ECSide配置实例

    ECSide是一款基于Java开发的开源数据管理框架,主要用于简化Web应用中的数据展现和操作。在本配置实例中,我们将探讨如何将ECSide集成到一个Web应用中,特别是涉及`web.xml`的配置。 首先,为了使用ECSide,你需要...

    Web项目所需ecside全部文件

    ECSide是一款基于Java开发的Web项目管理工具,主要用于协助开发者进行Web应用的开发、调试和维护工作。这个压缩包包含的"Web项目所需ecside全部文件"是ECSide的完整组件,使得用户能够在本地环境中顺利运行和使用...

Global site tag (gtag.js) - Google Analytics