Struts2 jQuery данные сетки не загружаются - PullRequest
1 голос
/ 20 июня 2011

Я новичок в JQgrid со Struts2.

Я пробовал использовать этот код, но я не получу никаких записей в сетке, но я получил все записи в действии.

testGrid.jsp

<%@ taglib prefix="s" uri="/struts-tags"%>
<%@ taglib prefix="sj" uri="/struts-jquery-tags"%>
<%@ taglib prefix="sjg" uri="/struts-jquery-grid-tags"%>

......
.......
<s:url id="remoteurl" action="jsontable"/>
                    <sjg:grid
                        id="gridtable"
                        caption="Application Data"
                        dataType="json"
                        href="%{remoteurl}"
                        pager="true"
                        gridModel="gridModel"
                        rowList="10,15,20"
                        rowNum="15"
                        rownumbers="true"
                    >
                        <sjg:gridColumn name="state" index="state" title="State" sortable="true"/>
                        <sjg:gridColumn name="city" index="city" title="City" sortable="false"/>
                        <sjg:gridColumn name="district" index="district" title="District" sortable="false"/>
                    </sjg:grid>

testAction.java

package com.sttl.rpsc.action;

import java.util.List;

import org.hibernate.Query;
import org.hibernate.Session;

import com.sttl.rpsc.action.base.BaseAction;
import com.sttl.rpsc.dataobject.Application;
import com.sttl.rpsc.util.HibernateUtil;

public class testAction extends BaseAction {


    private List<Application>      gridModel;
    private List<Application>      myCustomers;
    private Integer             rows             = 0;
    private Integer             page             = 0;
    private Integer             total            = 0;
    private Integer             record           = 0;
    private String              sord;
    private String              sidx;
    private String              searchField;
    private String              searchString;
    private String              searchOper;
    private boolean             loadonce         = false;



    public List<Application> getGridModel() {
        return gridModel;
    }
    public void setGridModel(List<Application> gridModel) {
        this.gridModel = gridModel;
    }
    public List<Application> getMyCustomers() {
        return myCustomers;
    }
    public void setMyCustomers(List<Application> myCustomers) {
        this.myCustomers = myCustomers;
    }
    public Integer getRows() {
        return rows;
    }
    public void setRows(Integer rows) {
        this.rows = rows;
    }
    public Integer getPage() {
        return page;
    }
    public void setPage(Integer page) {
        this.page = page;
    }
    public Integer getTotal() {
        return total;
    }
    public void setTotal(Integer total) {
        this.total = total;
    }
    public Integer getRecord() {
        return record;
    }
    public void setRecord(Integer record) {
        this.record = record;
    }
    public String getSord() {
        return sord;
    }
    public void setSord(String sord) {
        this.sord = sord;
    }
    public String getSidx() {
        return sidx;
    }
    public void setSidx(String sidx) {
        this.sidx = sidx;
    }
    public String getSearchField() {
        return searchField;
    }
    public void setSearchField(String searchField) {
        this.searchField = searchField;
    }
    public String getSearchString() {
        return searchString;
    }
    public void setSearchString(String searchString) {
        this.searchString = searchString;
    }
    public String getSearchOper() {
        return searchOper;
    }
    public void setSearchOper(String searchOper) {
        this.searchOper = searchOper;
    }
    public boolean isLoadonce() {
        return loadonce;
    }
    public void setLoadonce(boolean loadonce) {
        this.loadonce = loadonce;
    }

    public String getJSON()
    {
        return getAllApplicationData();
    }

    public String getAllApplicationData(){
        String result = SUCCESS;

        Query q = null;
        try{

            Session session = HibernateUtil.getSessionFactory().getCurrentSession();
            session.beginTransaction();
            q = session.createQuery("from Application");
            this.setGridModel(q.list()); 

            if(this.getGridModel()!=null)
                System.out.println("gridModel.Size() : "+this.getGridModel().size());
            else
                System.out.println("gridModel null");

            int to = (rows * page);
            int from = to - rows;


            //Count Rows (select count(*) from custumer)
            record = gridModel.size();

            System.out.println("record : "+record);
            //Your logic to search and select the required data.
            //gridModel = CustumerDAO.find(from, to);


            //calculate the total pages for the query
            total =(int) Math.ceil((double)record / (double)rows);
            System.out.println("total : "+total);

        }catch(Exception e){
            e.printStackTrace();
        }

        return result;
    }



}

struts.xml

<package name="default" extends="struts-default,json-default" namespace="/">

..........
...........

<action name="jsontable" class="com.sttl.rpsc.action.testAction" method="getJSON">
            <interceptor-ref name="basicStack" />
            <result name="success" type="tiles">/testgrid.tiles</result>
            <result name="error" type="redirect">/testgrid.tiles</result>
            <result name="cancel" type="redirect">/testgrid.tiles</result>          
        </action>

tiles.xml

<definition name="/testgrid.tiles" extends="baseLayoutNew">
    <put-attribute name="title" value="Test Grid" />
    <put-attribute name="body" value="/jsp/examination/testGrid.jsp" />
 </definition>

Здесь у меня есть размер списка: 183, и когда я выполняю итерацию в файле действий, я получаю все записи, но не могу попасть в сетку. Что я должен делать? Там нет ошибки, показывая там.

1 Ответ

2 голосов
/ 21 июня 2011

В вашей сетке вы ожидаете, что JSON будет перенастроен.Таким образом, в вашем отображении действий вы должны изменить тип результата на json следующим образом:

<action name="jsontable" class="com.sttl.rpsc.action.testAction" method="getJSON">
    <result name="success" type="json"/>
</action>

json тип результата добавляется к вашим типам результатов с помощью плагина Struts2 JSON .убедитесь, что плагин находится в вашем classpath и ваш пакет расширяется json-default.Указывая json в качестве типа результата, вы сериализуете свое действие как JSON, делая его доступным для кода javascript (в вашем случае - сетки) для чтения данных.

...