ajax - Liferay 6.2 portlet 中的 Ajax 调用

标签 ajax liferay alloy-ui liferay-aui

我是 Liferay 的初学者,我想进行 ajax 调用。我正在做的是: - 我在 jsp 页面中有一个按钮来进行 ajax 调用 变量在 javascript 代码中初始化,并在每次用户单击按钮时递增。此变量被传输到服务器以用作函数的参数。

代码片段

aui_ajax.jsp:

<input type="button" value = "Ajouter un projet" onClick="<portlet:namespace/>Test();return false;">
<div id="usersTable">
  <input type="button" value = "Ajouter un projet" onClick="   <portlet:namespace/>Test();return false;">
</div>
<div id="wait" style="display:none; width: 69px; height: 89px; border: 1px solid black; position: absolute; top: 50%; left: 50%; padding: 2px;">
 <img src='http://www.w3schools.com/jquery/demo_wait.gif' width="64" height="64" />  <br>Loading..
</div>

<script>
var i=1

function <portlet:namespace/>Test() {
    var i=1;
    AUI().use('aui-base','aui-io-request', function(A){
        i++;
        A.one('#wait').setStyle('display', 'block');
        var allRows=A.one('#usersTable').getHTML();

        var querystring = 'message:' + '1';

        //aui ajax call to get updated content
        A.io.request('<%=updaContentURL%>',{
        dataType: 'json',
        method: 'GET',
        data: querystring,
        on: {
             success: function() {
                var data=this.get('responseData');
                A.Array.each(data, function(obj, idx){


                    var tableRow=obj.firstName;
                    //allRows=allRows.trim()+tableRow.trim();



                    //A.one('#usersTable').empty();
                    //A.one('#usersTable').setHTML(tableRow.trim());
                  A.one('#usersTable').append(tableRow.trim());

                    A.one('#wait').setStyle('display','none');
                });
            }
        }
        });
        });
  }
</script>

ContentAutoUpdateAction.java

public class ContentAutoUpdateAction extends MVCPortlet {


public void serveResource(ResourceRequest resourceRequest,
        ResourceResponse resourceResponse)
    throws  IOException, PortletException {

    try {
        System.out.println("====serveResource========");
        JSONObject jsonUser=null;
        JSONArray usersJsonArray=JSONFactoryUtil.createJSONArray();

        resourceRequest.getParameter("message");
        int i=Integer.parseInt(message);    
        i++;
        System.out.println(i);



        //}
        PrintWriter out=resourceResponse.getWriter();
        System.out.println(usersJsonArray.toString());
        out.print(usersJsonArray.toString());
    }
    catch (Exception e) {
        e.printStackTrace();
    }
}

问题是我无法在 ContentAutoUpdateAction.java 中获取参数“message”

最佳答案

虽然是个老问题但还是想回答。

您必须为 portlet 启用 ajax。

<ajaxable>true</ajaxable>

在 liferay-portlet.xml 中

其次,您可以使用ajax传递参数

data: {
paramName1: paramValue,
paramName2: paramValue2
}

如果你想将它连接成一个查询字符串,那么你可以使用

var ajaxURL = "<portlet:resourceURL/>";
ajaxURL = ajaxURL + "&message=1";

然后使用 ajaxURL 作为 ajax 请求的 url。

关于ajax - Liferay 6.2 portlet 中的 Ajax 调用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/25160803/

相关文章:

javascript - 使用内置功能在 MVC6 中使用 JQuery AJAX 提交 Razor 表单

javascript - 如何防止重新获取AJAX数据?

java - 如何确定应用程序上下文中的对象?

liferay - 启动问题 - Liferay 7.1.2 GA3 -javax.servlet.ServletException

java - 从 Liferay 移除 Alloy UI

javascript - Alloy-ui 多个日期选择器将选择发送到其他输入

javascript - ajax PUT 不传输数组

java - LiferayDispatcherPortlet - 类的名称是什么?

javascript - Liferay 门户组件 : redirect to an other jsp page from javascript

javascript - 如何创建正确的 PHP json 响应