i want to use ajax and javascript in struts 1.1 application beca开发者_如何学编程use i want to make datagrid with insert,update,delete.
Creating Dynamic Grid Using Struts-1, Jsp, Java, Javascript
Grid.jsp
<%@ page language="java" contentType="text/html; charset=ISO-8859-1"
pageEncoding="ISO-8859-1"%>
<%@ taglib uri="/WEB-INF/struts-html.tld" prefix="html"%>
<%@ taglib uri="/WEB-INF/struts-bean.tld" prefix="bean" %>
<%@ taglib uri="/WEB-INF/struts-logic.tld" prefix="logic" %>
<script type="text/javascript" src="scripts/scrollabletable.js"></script>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<%@page import="java.util.ArrayList"%>
<%@page import="sme.struts.actionform.Grid_form"%>
<html:html>
<script type="text/javascript">
function adddata()
{
document.forms[0].action="Grid.do?parameter=add"
document.forms[0].submit()
document.forms[0].add.disabled=true
return true
}
</script>
<head>
<html:base />
<meta http-equiv="Content-Type" content="text/html; charset=ISO-8859-1">
<title>My Grid</title>
<style type="text/css">
<!--
.style5 {font-family: "Bookman Old Style"; font-weight: bold; font-size: 14px; }
.style6 {
font-size: 14px;
color: #CCCCCC;
}
.style10 {font-family: "Bookman Old Style"; font-size: 14; }
.style11 {font-size: 14}
.style13 {font-family: "Bookman Old Style"; font-weight: bold; font-size: 14px; color: #CCCCCC; }
-->
</style>
</head>
<body>
<%
String message=(String)request.getAttribute("gridmessage");
if(message==null)message="";
%>
<html:form action="/Grid" method="post">
<table width="100%" cellspacing="0" cellpadding="0">
<tr>
<td width="21%" class="style5">Name :<html:text property="name" /></td>
<td width="25%" class="style5">Description :<html:text property="description" /></td>
<td width="16%" class="style5">Age :<html:text property="age" /></td>
<td width="38%"><html:button property="add" value="Add" onclick="adddata()" /></td>
</tr>
<tr>
<td><%= message %></td>
<td> </td>
<td> </td>
<td> </td>
</tr>
</table>
<table id="myScrollTable" width="100%" cellspacing="0" cellpadding="0" border="1">
<thead>
<tr bgcolor="#333333">
<th width="14%"><span class="style13">Slno</span></th>
<th width="31%"><span class="style13">Name</span></th>
<th width="27%"><span class="style13">Description</span></th>
<th width="12%"><span class="style13">Age</span></th>
<th width="16%"> </th>
</tr>
</thead>
<tbody>
<%
int i=0;
if((ArrayList<Grid_form>)session.getAttribute("gridlist")!=null)
{
%>
<logic:iterate id="gridlist_id" name="gridlist">
<tr>
<td><span class="style10"> <%= i+1 %>
<a href="Grid.do?parameter=delete&listid=<%= i %>");return false;">Delete </a>
</span></td>
<td><span class="style10">
<bean:write name="gridlist_id" property="name" />
</span></td>
<td><span class="style10">
<bean:write name="gridlist_id" property="description" />
</span></td>
<td><span class="style10">
<bean:write name="gridlist_id" property="age" />
</span></td>
<td><span class="style11"></span></td>
</tr>
<%
i++;
%>
</logic:iterate>
<%
}
%>
</tbody>
</table>
<script type="text/javascript">
var t = new ScrollableTable(document.getElementById('myScrollTable'),200);
</script>
</html:form>
</body>
</html:html>
Action Servlet: Grid.java
package sme.struts.action;
import java.util.ArrayList;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpSession;
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 org.apache.struts.actions.DispatchAction;
import sme.struts.actionform.Grid_form;
import sme.struts.actionform.test_form;
public class Grid extends DispatchAction {
public ActionForward add(ActionMapping mapping, ActionForm form,
HttpServletRequest request, HttpServletResponse response)
throws Exception {
String message = "";
Grid_form gf = (Grid_form) form;
String name = gf.getName();
String description = gf.getDescription();
String age = gf.getAge();
ArrayList<Grid_form> al = null;// new ArrayList<Grid_form>();
HttpSession session = request.getSession();
al = (ArrayList<Grid_form>) session.getAttribute("gridlist");
Grid_form myform = new Grid_form();
if (al == null) {
al = new ArrayList<Grid_form>();
myform.setName(name);
myform.setDescription(description);
myform.setAge(age);
al.add(myform);
} else {
boolean flag = true;
for (int i = 0; i < al.size(); i++) {
if (al.get(i).getName().equals(name)) {
flag = false;
break;
}
}
if (flag == false) {
message = "Data already exists";
} else {
myform.setName(name);
myform.setDescription(description);
myform.setAge(age);
al.add(myform);
}
}
request.setAttribute("gridmessage", message);
session.setAttribute("gridlist", al);
System.out.println("Description is:::::" + gf.getDescription());
return mapping.findForward("addsuccess");
}
public ActionForward delete(ActionMapping mapping, ActionForm form,
HttpServletRequest request, HttpServletResponse response)
throws Exception {
Grid_form gf = (Grid_form) form;
ArrayList<Grid_form> al = null;// new ArrayList<Grid_form>();
HttpSession session = request.getSession();
al = (ArrayList<Grid_form>) session.getAttribute("gridlist");
String listid = request.getParameter("listid");
if (al != null) {
al.remove(Integer.parseInt(listid));
} else {
}
session.setAttribute("gridlist", al);
return mapping.findForward("addsuccess");
}
}
Action Form: Grid_form.java
package sme.struts.actionform;
import javax.servlet.http.HttpServletRequest;
import org.apache.struts.action.ActionErrors;
import org.apache.struts.action.ActionForm;
import org.apache.struts.action.ActionMapping;
public class Grid_form extends ActionForm {
private String name;
private String description;
private String age;
/**
* Method reset
*
* @param mapping
* @param request
*/
public void reset(ActionMapping mapping, HttpServletRequest request) {
// TODO Auto-generated method stub
}
public ActionErrors validate(ActionMapping mapping,
HttpServletRequest request) {
ActionErrors errors = new ActionErrors();
System.out.println("1");
// TODO Auto-generated method stub
return errors;
}
public String getAge() {
return age;
}
public void setAge(String age) {
this.age = age;
}
public String getDescription() {
return description;
}
public void setDescription(String description) {
this.description = description;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
}
scrollabletable.js
/**
*
* Scrollable HTML table
* http://www.webtoolkit.info/
*
**/
function ScrollableTable (tableEl, tableHeight, tableWidth) {
this.initIEengine = function () {
this.containerEl.style.overflowY = 'auto';
if (this.tableEl.parentElement.clientHeight - this.tableEl.offsetHeight < 0) {
this.tableEl.style.width = this.newWidth - this.scrollWidth +'px';
} else {
this.containerEl.style.overflowY = 'hidden';
this.tableEl.style.width = this.newWidth +'px';
}
if (this.thead) {
var trs = this.thead.getElementsByTagName('tr');
for (x=0; x<trs.length; x++) {
trs[x].style.position ='relative';
trs[x].style.setExpression("top", "this.parentElement.parentElement.parentElement.scrollTop + 'px'");
}
}
if (this.tfoot) {
var trs = this.tfoot.getElementsByTagName('tr');
for (x=0; x<trs.length; x++) {
trs[x].style.position ='relative';
trs[x].style.setExpression("bottom", "(this.parentElement.parentElement.offsetHeight - this.parentElement.parentElement.parentElement.clientHeight - this.parentElement.parentElement.parentElement.scrollTop) + 'px'");
}
}
eval("window.attachEvent('onresize', function () { document.getElementById('" + this.tableEl.id + "').style.visibility = 'hidden'; document.getElementById('" + this.tableEl.id + "').style.visibility = 'visible'; } )");
};
this.initFFengine = function () {
this.containerEl.style.overflow = 'hidden';
this.tableEl.style.width = this.newWidth + 'px';
var headHeight = (this.thead) ? this.thead.clientHeight : 0;
var footHeight = (this.tfoot) ? this.tfoot.clientHeight : 0;
var bodyHeight = this.tbody.clientHeight;
var trs = this.tbody.getElementsByTagName('tr');
if (bodyHeight >= (this.newHeight - (headHeight + footHeight))) {
this.tbody.style.overflow = '-moz-scrollbars-vertical';
for (x=0; x<trs.length; x++) {
var tds = trs[x].getElementsByTagName('td');
tds[tds.length-1].style.paddingRight += this.scrollWidth + 'px';
}
} else {
this.tbody.style.overflow = '-moz-scrollbars-none';
}
var cellSpacing = (this.tableEl.offsetHeight - (this.tbody.clientHeight + headHeight + footHeight)) / 4;
this.tbody.style.height = (this.newHeight - (headHeight + cellSpacing * 2) - (footHeight + cellSpacing * 2)) + 'px';
};
this.tableEl = tableEl;
this.scrollWidth = 16;
this.originalHeight = this.tableEl.clientHeight;
this.originalWidth = this.tableEl.clientWidth;
this.newHeight = parseInt(tableHeight);
this.newWidth = tableWidth ? parseInt(tableWidth) : this.originalWidth;
this.tableEl.style.height = 'auto';
this.tableEl.removeAttribute('height');
this.containerEl = this.tableEl.parentNode.insertBefore(document.createElement('div'), this.tableEl);
this.containerEl.appendChild(this.tableEl);
this.containerEl.style.height = this.newHeight + 'px';
this.containerEl.style.width = this.newWidth + 'px';
var thead = this.tableEl.getElementsByTagName('thead');
this.thead = (thead[0]) ? thead[0] : null;
var tfoot = this.tableEl.getElementsByTagName('tfoot');
this.tfoot = (tfoot[0]) ? tfoot[0] : null;
var tbody = this.tableEl.getElementsByTagName('tbody');
this.tbody = (tbody[0]) ? tbody[0] : null;
if (!this.tbody) return;
if (document.all && document.getElementById && !window.opera) this.initIEengine();
if (!document.all && document.getElementById && !window.opera) this.initFFengine();
}
struts-config.xml
<?xml version="1.0" encoding="ISO-8859-1" ?>
<!DOCTYPE struts-config PUBLIC
"-//Apache Software Foundation//DTD Struts Configuration 1.2//EN"
"http://jakarta.apache.org/struts/dtds/struts-config_1_2.dtd">
<!--
This is a blank Struts configuration file with an example
welcome action/page and other commented sample elements.
Tiles and the Struts Validator are configured using the factory defaults
and are ready-to-use.
NOTE: If you have a generator tool to create the corresponding Java classes
for you, you could include the details in the "form-bean" declarations.
Otherwise, you would only define the "form-bean" element itself, with the
corresponding "name" and "type" attributes, as shown here.
-->
<struts-config>
<!-- ============================================ Data Source Configuration -->
<data-sources>
<data-source key="smeds" type="org.apache.commons.dbcp.BasicDataSource">
<set-property
property="driverClassName"
value="oracle.jdbc.driver.OracleDriver" />
<set-property
property="url"
value="jdbc:oracle:thin:@192.168.100.136:1521:ortelapp" />
<set-property
property="username"
value="scott" />
<set-property
property="password"
value="tigerscott" />
<set-property
property="maxActive"
value="10" />
<set-property
property="maxWait"
value="5000" />
<set-property
property="defaultAutoCommit"
value="false" />
<set-property
property="defaultReadOnly"
value="false" />
</data-source>
</data-sources>
<!-- ================================================ Form Bean Definitions -->
<form-beans>
<form-bean
name="MyregForm"
type="myregistration.MyregForm"/>
<form-bean
name="my_form"
type="formbean.my_form"/>
<form-bean name="file_reg_v1_form"
type="sme.struts.actionform.file_reg_v1_form" />
<form-bean name="test_form"
type="sme.struts.actionform.test_form" />
<form-bean name="Grid_form"
type="sme.struts.actionform.Grid_form" />
<!-- sample form bean descriptor for an ActionForm
<form-bean
name="inputForm"
type="app.InputForm"/>
end sample -->
<!-- sample form bean descriptor for a DynaActionForm
<form-bean
name="logonForm"
type="org.apache.struts.action.DynaActionForm">
<form-property
name="username"
type="java.lang.String"/>
<form-property
name="password"
type="java.lang.String"/>
</form-bean>
end sample -->
</form-beans>
<!-- ========================================= Global Exception Definitions -->
<global-exceptions>
<!-- sample exception handler
<exception
key="expired.password"
type="app.ExpiredPasswordException"
path="/changePassword.jsp"/>
end sample -->
</global-exceptions>
<!-- =========================================== Global Forward Definitions -->
<global-forwards>
<!-- Default forward to "Welcome" action -->
<!-- Demonstrates using index.jsp to forward -->
<forward
name="welcome"
path="/Welcome.do"/>
<forward
name="sessionexpired"
path="/ctss_logout.jsp"/>
</global-forwards>
<!-- =========================================== Action Mapping Definitions -->
<action-mappings>
<!-- Default "Welcome" action -->
<!-- Forwards to Welcome.jsp -->
<action
path="/DataSource"
type="test.TestDataSource">
<forward name="success" path="/pages/success.jsp"/>
</action>
<action
path="/Welcome"
forward="/pages/Welcome.jsp"/>
<action
path="/TestAction"
type="roseindia.net.TestAction">
<forward name="testAction" path="/pages/TestAction.jsp"/>
</action>
<action
path="/myaction"
type="actionservlets.my_servlet"
name="my_form"
scope="request"
validate="true"
input="/u_login.jsp">
<forward name="myentrysuccess" path="/afterlogin.jsp" />
</action>
<!-- Bikram -->
<action
path="/file_reg_v1"
type="sme.struts.action.file_reg_v1"
name="file_reg_v1_form"
validate="true"
scope="request"
input="/file_reg_v1.jsp">
<forward name="uploadsuccess" path="/file_reg_v1.jsp" />
</action>
<action
path="/test"
type="sme.struts.action.test"
name="test_form"
validate="true"
scope="request"
input="/test.jsp"
>
<forward name="success" path="/test.jsp" />
</action>
<action
path="/Grid"
type="sme.struts.action.Grid"
name="Grid_form"
validate="true"
parameter="parameter"
scope="request"
input="/Grid.jsp"
>
<forward name="addsuccess" path="/Grid.jsp" />
<forward name="addfailure" path="/Grid.jsp" />
</action>
<action
path="/Tiles/Example"
forward="Tiles.Example"/>
<!-- sample input and input submit actions
<action
path="/Input"
type="org.apache.struts.actions.ForwardAction"
parameter="/pages/Input.jsp"/>
<action
path="/InputSubmit"
type="app.InputAction"
name="inputForm"
scope="request"
validate="true"
input="/pages/Input.jsp"/>
<action
path="/edit*"
type="app.Edit{1}Action"
name="inputForm"
scope="request"
validate="true"
input="/pages/Edit{1}.jsp"/>
end samples -->
</action-mappings>
<!-- ============================================= Controller Configuration -->
<controller
processorClass="org.apache.struts.tiles.TilesRequestProcessor"/>
<!-- ======================================== Message Resources Definitions -->
<message-resources parameter="MessageResources" />
<!-- =============================================== Plug Ins Configuration -->
<!-- ======================================================= Tiles plugin -->
<!--
This plugin initialize Tiles definition factory. This later can takes some
parameters explained here after. The plugin first read parameters from
web.xml, thenoverload them with parameters defined here. All parameters
are optional.
The plugin should be declared in each struts-config file.
- definitions-config: (optional)
Specify configuration file names. There can be several comma
separated file names (default: ?? )
- moduleAware: (optional - struts1.1)
Specify if the Tiles definition factory is module aware. If true
(default), there will be one factory for each Struts module.
If false, there will be one common factory for all module. In this
later case, it is still needed to declare one plugin per module.
The factory will be initialized with parameters found in the first
initialized plugin (generally the one associated with the default
module).
true : One factory per module. (default)
false : one single shared factory for all modules
- definitions-parser-validate: (optional)
Specify if xml parser should validate the Tiles configuration file.
true : validate. DTD should be specified in file header (default)
false : no validation
Paths found in Tiles definitions are relative to the main context.
-->
<plug-in className="org.apache.struts.tiles.TilesPlugin" >
<!-- Path to XML definition file -->
<set-property property="definitions-config"
value="/WEB-INF/tiles-defs.xml" />
<!-- Set Module-awareness to true -->
<set-property property="moduleAware" value="true" />
</plug-in>
<!-- =================================================== Validator plugin -->
<plug-in className="org.apache.struts.validator.ValidatorPlugIn">
<set-property
property="pathnames"
value="/WEB-INF/validator-rules.xml,/WEB-INF/validation.xml"/>
</plug-in>
</struts-config>
There's a tutorial here that shows you how to. I've done it a while back.
Basically, what you have to do is to create a DispatchAction
or LookupDispatchAction
that returns a null
result so that Struts doesn't have to process the ActionForward
.
Instead, for your action methods, you'll have to write your responses as text into the HttpServletResponse
.
Other solution is AjaxAnywhere
or view AjaxStruts
精彩评论