如何用javascript调用Struts2 Action Class方法中的方法

问题描述 投票:0回答:3

我们当前使用以下 JavaScript 在其中一个字段值发生更改时提交表单。

var url = "project/location/myAction.action?name="+ lname ; 
document.forms[0].action = url;
document.forms[0].submit();

调用以下 Struts 2 操作

<action name="myAction" class="project.location.NameAction">
    <result name="success" type="tiles">myAction</result>   
</action>

然后转到

execute()
Action
NameAction
方法,我必须在其中检查表单是否是从 JavaScript 提交的。

我更喜欢直接从 JavaScript 调用

findName()
中的
NameAction
方法。 换句话说,我希望 javascript 的行为类似于以下 JSP 代码:

<s:submit method="findName" key="button.clear" cssClass="submit" >
javascript jsp struts2 xml-configuration struts-action
3个回答
2
投票

有不同的方法可以实现您想要的,但可能更简单的是将不同的操作映射到同一操作类文件的不同方法,例如。带注释:

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 ;

1
投票

您可以使用相同的操作类来使用

method
属性

映射不同的方法
<action name="myAction" class="project.location.NameAction" method="findName">

默认情况下,如果省略

method
属性,则使用
execute
方法。

此方法需要更改操作名称以及 URL 来映射操作。 如果您想为不同的操作保留相同的 URL,那么您应该将方法名称作为参数传递给操作。 然后在execute方法中解析该参数为方法名并调用对应的方法。

在以前的版本中启用 DMI 来调用该方法时,您可以使用

method
标签的
s:submit
属性。目前,
method:
参数名称被
params
拦截器阻止,即使它到达了动作映射器。

您还可以从如何从 struts2 中的参数列表中排除提交操作中阅读其他可能性。


0
投票

为了完整起见,以下是我如何实施 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”添加到调用

action
函数的表单的
selectNameInfo()
来形成 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>
© www.soinside.com 2019 - 2024. All rights reserved.