0

我正在使用 struts 2.3.7、struts2-jquery-grid-plugin-3.5.0 和 hibernate 3.6。我想在进行 ajax 调用后重新加载 jqgrid。

我有一个包含三个按钮的 jDialog 框,单击按钮后,我们需要执行一些操作,例如 Ajax 调用,然后我必须重新加载 jqgrid 如何实现。

我的 jDialog

<sj:dialog 
         id="mybuttondialog"
        buttons="{
                'Approove':function() { approoveButton(); },
                'Cancel':function() { cancelButton(); },
                'Deny':function() { denyButton(); }
                }"
        autoOpen="false"
        modal="true"
        title="Assign Issues"
        width="375"
        resizable="false"
        draggable="true"
        closeTopics="closeThisDialog"
>

我的 jqGrid 是

 <div id="targetDivToRefresh">
    <sjg:grid
        id="gridtable"
        caption="Issue-Summary"
        dataType="json"
        href="%{remoteurl}"
        pager="true"
        gridModel="gridModel"
        rowList="10,15,20"
        rowNum="15"
        rownumbers="true"
        reloadTopics="reloadGrid"
    >
        <sjg:gridColumn name="issue_id"  id="issueId"  index="id" title="Issue-ID" formatter="integer"  sortable="false"/>
        <sjg:gridColumn name="issue_description" index="id" title="Issue-Details"  sortable="false"/>
        <sjg:gridColumn name="issue_raised_date" index="date" title="Issue-Date"  formatter="date"  sortable="false"/>

        <sjg:gridColumn name="issue_id"   index="issues" title="Action" sortable="false" formatter="formatLink"/>
        <sjg:gridColumn name="assigned"  index="assigned" title="Assigned To"  sortable="false"/>
    </sjg:grid>
        </div>

单击“Acton”列后,jDialog 框打开,我必须单击任何按钮,即 Approove、Deny 按钮来执行一些操作。完成 ajax 调用后,我必须重新加载 jqgrid。我使用 customFormatter 作为

function formatLink(cellvalue, options, rowObject) {

                      var issueId=rowObject.issue_id;

                        return "<a href='#' onClick='javascript:openDialog("+issueId+")'>" + issueId+ "</a>";

                }
                function openDialog(issue) {

                        global_id=issue;
                        $("#mybuttondialog").dialog().text('Your are going to assign Issue-Id:' + issue);
                        $("#mybuttondialog").dialog('open');

                }

但是我尝试过这样的事情来重新加载网格:

$("#gridtable").trigger("reloadGrid"); // where #gridtable is my jqGrid idName

请帮帮我,我是第一次使用jqgrid。

Edited Section

实际上 ajax 调用处于演示阶段,但是代码如下。

function approoveButton()
        {
            $("#mybuttondialog").load("<s:property value='issueTrackerUrl'/>?id="+global_id);

        }

这里的 issueTrackerUrl 是一个成功进行 ajax 调用的操作。在这里我重新加载 jqgrid

 function reload() 
        {
              $("#gridtable").trigger("reloadGrid"); 
        }

在此处输入图像描述

4

1 回答 1

3

您需要在 ajax 调用成功时触发重新加载功能,然后只有您可以重新加载网格。

$("#mybuttondialog").load("<s:property value='issueTrackerUrl'/>?id="+global_id,  function(responseText, statusText, xhr)
        {
                if(statusText == "success")
                        alert("Successfully loaded the content!");
                       $("#gridtable").trigger("reloadGrid");
                if(statusText == "error")
                        alert("An error occurred: " + xhr.status + " - " + xhr.statusText);
        });

在ajax成功调用那些行。issueTrackerUrl 应该返回成功或错误。

于 2013-01-07T05:43:07.287 回答