我们目前使用以下 javascript 在其中一个字段值更改时提交表单。
var url = "project/location/myAction.action?name="+ lname ;
document.forms[0].action = url;
document.forms[0].submit();
调用以下 Struts2 操作
<action name="myAction" class="project.location.NameAction">
<result name="success" type="tiles">myAction</result>
</action>
然后转到 Action 类的 execute()
方法NameAction
我必须检查表单是否是从 javascript 提交的。
我更愿意直接从javascript调用NameAction
中的findName()
方法。 换句话说,我希望javascript的行为类似于下面的jsp代码。
<s:submit method="findName" key="button.clear" cssClass="submit" >
有不同的方法可以实现您想要的,但可能更简单的是将不同的操作映射到同一操作类文件的不同方法,例如。 带有注释:
public class NameAction {
@Action("myAction")
public String execute(){ ... }
@Action("myActionFindName")
public String findName(){ ... }
}
或使用 XML:
<action name="myAction" class="project.location.NameAction">
<result name="success" type="tiles">myAction</result>
</action>
<action name="myActionFindName" class="project.location.NameAction" method="findName">
<result name="success" type="tiles">myAction</result>
</action>
然后在javascript中:
var url = "project/location/myActionFindName.action?name="+ lname ;
您可以使用同一操作类来映射不同的方法 method
<action name="myAction" class="project.location.NameAction" method="findName">
默认情况下,如果省略method
属性将使用execute
方法。
此方法需要更改操作名称,从而更改 URL 以映射操作。 如果要为不同的操作保留相同的 URL,则应将方法名称作为参数传递给操作。 然后在执行方法中解析此参数以获取方法名称并调用相应的方法。
在以前的版本中启用 DMI 来调用该方法时,您可以使用 s:submit
标记的 method
属性。目前,method:
参数名称被params
侦听器阻止,即使它到达操作映射器也是如此。
您还可以从如何从 struts2 中的参数列表中排除提交操作中阅读其他可能性。
为了完整起见,以下是我如何实施Andrea和Roman的建议。
当用户在firstName
和lastName
字段中输入数据时,我们会向他们显示一个名称列表,以供选择以填写表单的其余部分。 该 jsp 是
<div class="row">
<div class=" col-sm-2 col-xs-12 no-padding-right text-right"><span class="required">*</span><label class="pull-right" for="lastNameId"><s:text name="lastName"></s:text>:</label></div>
<div class=" col-sm-2 col-xs-12 no-padding-right ">
<s:textfield name="lastName" id="lastNameId" maxlength="50" onchange ="dirtyFlag();" onblur="selectNameInfo('newRequest');" class="form-control"/>
</div>
<div class=" col-sm-2 col-xs-12 no-padding-right text-right " ><span class="required">*</span><label class="pull-right" for="firstNameId"><s:text name="firstName"></s:text>:</label></div>
<div class=" col-sm-2 col-xs-12 no-padding-right ">
<s:textfield name="firstName" id="firstNameId" maxlength="50" onchange ="dirtyFlag();" onblur="selectNameInfo('newRequest');" class="form-control"/>
</div>
</div>
JavaScript 是
function selectNameInfo(formId) {
var lastName = document.forms[0].elements["lastNameId"].value;
var firstName = document.forms[0].elements["firstNameId"].value;
if(lastName != "" && firstName != ""){
clearDirtyFlag();
var oldAction = document.getElementById(formId).action;
var actionName = document.getElementById(formId).name;
var url = oldAction.replace(actionName,actionName+"_NameSearch");
document.forms[0].action = url;
document.forms[0].submit();
};
}
javascript 通过将"_NameSearch"添加到调用 selectNameInfo()
函数的表单的action
来形成 url。 在这种情况下,新操作newRequest_NameSearch
转到以下xml,该xml调用操作类的generateNameList()
方法,而无需使用DMI,这是我最初的问题。
<action name="newRequest_NameSearch" class="gov.mo.dnr.egims.controller.evaluation.NewRequestAction" method = "generateNameList">
<result name="success" type="tiles">newRequest</result>
<result name="nameSearch" type="tiles">selectNameInfo</result>
<result name="error" type="tiles">error</result>
</action>