先贴前台代码,在获取到值后插入数据库,下面是迭代输出所有数据,每条数据后面是delete,可进行删除
<body>
<s:form action="tUserNameAction_add" method="get" name="addform">
<s:textfield name="username" label="username"></s:textfield>
<s:textfield name="password" label="password"></s:textfield>
<s:textfield name="email" label="email"></s:textfield>
<s:textfield name="identity" label="identity"></s:textfield>
<s:submit name="addsubmit" label="submit"></s:submit>
</s:form>
<table>
<tr>
<th>id</th>
<th>username</th>
<th>password</th>
<th>email</th>
<th>identity</th>
<th>delete</th>
</tr>
<s:iterator value="userList">
<tr>
<td><s:property value="id" /></td>
<td><s:property value="username" /></td>
<td><s:property value="password" /></td>
<td><s:property value="email" /></td>
<td><s:property value="identity" /></td>
<td><a href='<s:url action="tUserNameAction_delete">
<s:param name="did" value="id"/></s:url>'>delete</a></td>
</tr>
</s:iterator>
</table>
</body>
action中的内容
T_TestUserDao dao = new T_TestUserDao();
//不能新new一个arraylist
//private List<T_TestUser> userList = new ArrayList<T_TestUser>();
private List<T_TestUser> userList = null;
public String delete(){
dao.delete(did);
userList = dao.findAll();
return "add";//指示再次进入当前页面
}
如果userList每次加载都进行实例化,点击delete会删除数据库数据并重新进入当前页面,但这时遇到一个问题,新删除的数据会在下一次有新操作时才会在页面刷新,即jsp页面获取到的userList保存的是上一次的数据。
赋初值null解决问题,具体原因尚未清楚,先mark,以后深究。