AUI输入onchange检测不起作用

时间:2017-12-27 10:38:30

标签: javascript liferay-6 liferay-aui

我正在使用liferay 6.1。 我的JSP有输入文本。我在输入文本上写入值,并希望将该值传递给Portlet控制器。但该动作不会发送给控制器。

JSP代码

 <form:input type="text"  name="id" path="id" onchange="" onkeydown=""/>
<aui:script use="event, node">
        AUI().ready('liferay-portlet-url','node',function(A){
            var actionURL = Liferay.PortletURL.createActionURL();
            actionURL.setWindowState("<%=LiferayWindowState.NORMAL.toString() %>");
            actionURL.setPortletMode("<%=LiferayPortletMode.VIEW %>");
            actionURL.setParameter("param","This value comes from Javascript");
            actionURL.setParameter("javax.portlet.action","actionMethodByJavaApi");

            A.one("#id").set('onchange', actionURL.toString());
            A.on("change",function(e){
            var idSelect=  A.one("#id").val();
                 }); 

        });
</aui:script>

在控制器中

@ProcessAction(name="actionMethodByJavaApi")
    public void renderDOB(BindingResult bndingResult, ActionRequest request, ActionResponse response, SessionStatus sessionStatus, Model model)
            throws SystemException, IOException, PortalException, AddressException {
        logger.info("DOB Action");
//      String sampleParam = ParamUtil.get(request, "param", "defaultValue");
//      logger.info("Sample Param is ::"+sampleParam);
    }

1 个答案:

答案 0 :(得分:1)

我认为您必须使用AUI标记声明您的表单,例如:

<aui:form>
<aui:fieldset>
    <aui:input name="verb" id="verb" type="text">
        <aui:validator name="required"/>
    </aui:input>
    <aui:button type="submit" class="btn btn-primary" id="submit" value="Generate"/>
</aui:fieldset>

显然你想要的是来自javascript的Ajax调用/调用,

您可以查看本教程http://www.opensource-techblog.com/2015/07/aui-ajax-in-liferay-portlet.html 它公开了一个在Ajax调用中使用的资源。