Struts2的action的实现:
package org.gordon;
data:image/s3,"s3://crabby-images/370e0/370e053b28c0d1e5a884270fad646284f2d183b3" alt=""
import java.io.IOException;
import java.io.PrintWriter;
import java.util.ArrayList;
import java.util.HashSet;
import java.util.Iterator;
import java.util.List;
import java.util.Map;
import java.util.Set;
data:image/s3,"s3://crabby-images/370e0/370e053b28c0d1e5a884270fad646284f2d183b3" alt=""
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
data:image/s3,"s3://crabby-images/370e0/370e053b28c0d1e5a884270fad646284f2d183b3" alt=""
import org.apache.struts2.interceptor.ApplicationAware;
import org.apache.struts2.interceptor.ServletRequestAware;
import org.apache.struts2.interceptor.ServletResponseAware;
data:image/s3,"s3://crabby-images/370e0/370e053b28c0d1e5a884270fad646284f2d183b3" alt=""
import com.opensymphony.xwork2.ActionSupport;
data:image/s3,"s3://crabby-images/370e0/370e053b28c0d1e5a884270fad646284f2d183b3" alt=""
public class AutoCompleteAction extends ActionSupport implements
data:image/s3,"s3://crabby-images/16507/1650758e64773369e558bf6a35239aa629f2eb9d" alt=""
ServletRequestAware, ServletResponseAware, ApplicationAware
{
data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
private HttpServletRequest request;
private HttpServletResponse response;
private Map map ;
private String key;
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
public void setServletRequest(HttpServletRequest request)
{
this.request = request;
}
data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
public void setServletResponse(HttpServletResponse response)
{
this.response = response;
}
data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
public void setApplication(Map map)
{
this.map = map;
}
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
public void setKey(String key)
{
this.key = key;
}
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
private String getAutoCompleteInformation(List list)
{
StringBuffer sb = new StringBuffer();
sb.append("<response>");
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
for (Iterator it = list.iterator(); it.hasNext();)
{
String str = (String) it.next();
sb.append(createXMLView(str));
}
sb.append("</response>");
return sb.toString();
}
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
private List<String> createResults()
{
Set info = (Set) map.get("autoComplete");
List<String> list = null;
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
if(info!=null)
{
list = new ArrayList<String>();
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
for (Iterator it = info.iterator(); it.hasNext();)
{
String str = (String) it.next();
String getStr = str.toUpperCase();
String keyword = key.toUpperCase();
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
if(getStr.startsWith(keyword))
{
list.add(str);
}
}
}
return list;
}
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
private String createXMLView(String str)
{
StringBuffer sb = new StringBuffer();
sb.append("<value>");
sb.append(str);
sb.append("</value>");
return sb.toString();
}
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
public String addAutoComplete()
{
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
if(map.containsKey("autoComplete"))
{
Set<String> set = null;
set = (Set) map.get("autoComplete");
set.add(key);
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
} else
{
Set<String> set = new HashSet<String>();
set.add(key);
map.put("autoComplete", set);
}
return SUCCESS;
}
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
public void returnAutoComplete()
{
PrintWriter out = null;
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
try
{
out = response.getWriter();
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
} catch (IOException e)
{
e.printStackTrace();
}
List list = createResults();
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
if(list != null && list.size()>0)
{
response.setContentType("text/xml");
response.setHeader("Cache-Control", "no-cache");
out.println(getAutoCompleteInformation(list));
out.close();
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
} else
{
response.setStatus(204);
}
}
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
public String execute()
{
addAutoComplete();
return SUCCESS;
}
}
data:image/s3,"s3://crabby-images/370e0/370e053b28c0d1e5a884270fad646284f2d183b3" alt=""
html
1data:image/s3,"s3://crabby-images/16507/1650758e64773369e558bf6a35239aa629f2eb9d" alt=""
<%
@ page language="java" pageEncoding="utf-8"%>
2data:image/s3,"s3://crabby-images/16507/1650758e64773369e558bf6a35239aa629f2eb9d" alt=""
<%
@ taglib uri="/struts-tags" prefix="s"%>
3
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
4
<html>
5
<head>
6
<title>Ajax Auto Complete</title>
7data:image/s3,"s3://crabby-images/16507/1650758e64773369e558bf6a35239aa629f2eb9d" alt=""
<style type="text/css">data:image/s3,"s3://crabby-images/87db9/87db9337486e6758d772829a26342839bc8c1a52" alt=""
8data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
9data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
.mouseOut {
}{
10
background: #708090;
11
color: #FFFAFA;
12
}
13data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
14data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
.mouseOver {
}{
15
background: #FFFAFA;
16
color: #000000;
17
}
18
</style>
19data:image/s3,"s3://crabby-images/16507/1650758e64773369e558bf6a35239aa629f2eb9d" alt=""
<script type="text/javascript">
20
var xmlHttp;
21
var completeDiv;
22
var inputField;
23
var nameTable;
24
var nameTableBody;
25data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
26data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
function createXMLHttpRequest()
{
27data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
if (window.ActiveXObject)
{
28
xmlHttp = new ActiveXObject("Microsoft.XMLHTTP");
29
}
30data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
else if (window.XMLHttpRequest)
{
31
xmlHttp = new XMLHttpRequest();
32
}
33
}
34data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
35data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
function initVars()
{
36
inputField = document.getElementById("names");
37
nameTable = document.getElementById("name_table");
38
completeDiv = document.getElementById("popup");
39
nameTableBody = document.getElementById("name_table_body");
40
}
41data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
42data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
function findNames()
{
43
initVars();
44data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
if (inputField.value.length > 0)
{
45
createXMLHttpRequest();
46
var url = "getInfo.action?key=" + escape(inputField.value) +"&time=" + new Date().getTime();
47
xmlHttp.open("GET", url, true);
48
xmlHttp.onreadystatechange = callback;
49
xmlHttp.send(null);
50data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
} else
{
51
clearNames();
52
}
53
}
54data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
55data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
function callback()
{
56data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
if (xmlHttp.readyState == 4)
{
57data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
if (xmlHttp.status == 200)
{
58
setNames(xmlHttp.responseXML.getElementsByTagName("value"));
59data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
} else
{
60
clearNames();
61
}
62
}
63
}
64
65data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
function setNames(the_names)
{
66
clearNames();
67
var size = the_names.length;
68
setOffsets();
69
var row, cell, txtNode;
70data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
for (var i = 0; i < size; i++)
{
71
var nextNode = the_names[i].firstChild.data;
72
row = document.createElement("tr");
73
cell = document.createElement("td");
74data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
75data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
cell.onmouseout = function()
{this.className='mouseOver';};
76data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
cell.onmouseover = function()
{this.className='mouseOut';};
77
cell.setAttribute("bgcolor", "#FFFAFA");
78
cell.setAttribute("border", "0");
79data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
cell.onclick = function()
{ populateName(this); } ;
80data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
81
txtNode = document.createTextNode(nextNode);
82
cell.appendChild(txtNode);
83
row.appendChild(cell);
84
nameTableBody.appendChild(row);
85
}
86
createClose();
87
}
88data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
89data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
function createClose()
{
90
row = document.createElement("tr");
91
cell = document.createElement("td");
92
txtNode = document.createTextNode("close");
93
cell.appendChild(txtNode);
94
cell.setAtrribute();
95
row.appendChild(cell);
96
nameTableBody.appendChild(row);
97
}
98data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
function setOffsets()
{
99
var end = inputField.offsetWidth;
100
var left = calculateOffsetLeft(inputField);
101
var top = calculateOffsetTop(inputField) + inputField.offsetHeight;
102data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
103
completeDiv.style.border = "black 1px solid";
104
completeDiv.style.left = left + "px";
105
completeDiv.style.top = top + "px";
106
nameTable.style.width = end + "px";
107
}
108
109data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
function calculateOffsetLeft(field)
{
110
return calculateOffset(field, "offsetLeft");
111
}
112data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
113data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
function calculateOffsetTop(field)
{
114
return calculateOffset(field, "offsetTop");
115
}
116data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
117data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
function calculateOffset(field, attr)
{
118
var offset = 0;
119data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
while(field)
{
120
offset += field[attr];
121
field = field.offsetParent;
122
}
123
return offset;
124
}
125data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
126data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
function populateName(cell)
{
127
inputField.value = cell.firstChild.nodeValue;
128
clearNames();
129
}
130data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
131data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
function clearNames()
{
132
var ind = nameTableBody.childNodes.length;
133data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
for (var i = ind - 1; i >= 0 ; i--)
{
134
nameTableBody.removeChild(nameTableBody.childNodes[i]);
135
}
136
completeDiv.style.border = "none";
137
}
138data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
139
</script>
140
</head>
141
<body>
142
<h1>Ajax Auto Complete Example</h1>
143
<s:form action="search">
144
<s:textfield label="Input the info which you want to search"
145
name="key" id="names" cssStyle="height:20;" maxlength="20" onkeyup="findNames();"></s:textfield>
146
<s:submit label="Search"></s:submit>
147
</s:form>
148
<div style="position:absolute;" id="popup">
149
<table id="name_table" bgcolor="#FFFAFA" border="0" cellspacing="0" cellpadding="0"/>
150
<tbody id="name_table_body">
151
</tbody>
152
</table>
153
</div>
154
</body>
155
</html>
156data:image/s3,"s3://crabby-images/370e0/370e053b28c0d1e5a884270fad646284f2d183b3" alt=""
157data:image/s3,"s3://crabby-images/370e0/370e053b28c0d1e5a884270fad646284f2d183b3" alt=""
注:引入struts2的用到的jar struts.xml文件 修改web.xml文件。
posted on 2008-08-30 18:53
Gordon 阅读(326)
评论(0) 编辑 收藏 所属分类:
Ajax