我正在开发一个Struts 2项目,问题在于我正在使用
我的<constant name="struts.ui.theme" value="simple"/>
中的struts.xml
用于我的JSP页面的布局(例如,根据应用的CSS,在一行中排列2-3个文本),但是我无法在同一个页面上显示验证错误jsp页面由于theme="simple"
。
配置:
<struts>
<!-- Configuration for the default package. -->
<constant name="struts.ui.theme" value="simple"/>
<package name="default" extends="struts-default">
<action name="validateUser" class="login.LoginAction">
<result name="SUCCESS">/welcome.jsp</result>
<result name="input">/login.jsp</result>
</action>
</package>
</struts>
动作:
public class LoginAction extends ActionSupport{
private String username; // getter and setter
private String password; // getter and setter
@Override
public String execute() {
// some business logic here....
return "SUCCESS";
}
//simple validation
@Override
public void validate(){
if("".equals(getUsername())){
addFieldError("username", getText("username.required"));
}
if("".equals(getPassword())){
addFieldError("password", getText("password.required"));
}
}
}
查看:
<s:form action="validateUser" validate="true" >
<table>
<tr>
<td>username</td>
<td><s:textfield label="username" name="username" /><td/>
</tr>
<tr>
<td>password</td>
<td><s:password label="password" name="password" /><td/>
<tr>
<td> <s:submit label="submit" name="submit"/></td>
</tr>
</table>
</s:form>
有没有办法用我的CSS维护布局并使用Struts 2验证?
答案 0 :(得分:3)
当然! XHTML主题会自动为您的输入标记添加fieldError
标记;
使用简单主题时,您需要手动添加它们,并为您的代码添加一个ID以匹配它们(除非它会自动生成,并且更难以发现):
<td>
<s:textfield id="username" label="username" name="username" />
<s:fielderror fieldName="username" />
</td>
<td>
<s:password id="password" label="password" name="password" />
<s:fielderror fieldName="password" />
</td>
P.S:我猜这些都在拼写错误中,错误只在问题中,而不是在真正的代码中,但你有:
<td/>
,<tr>
和<tr>
只有一个<td>
而未指定colspan="2"
。