0

Dojodojox.grid.DataGridとサーブレットからのデータを使用したいと思います。

問題:サーブレットから返されたデータが表示されず、「申し訳ありませんが、エラーが発生しました」というメッセージだけが表示されます。

JSON文字列をHTMLに配置するだけで、機能します。ARRRRGGH。

誰か助けてくれませんか!

ありがとうジェフポーター

サーブレットコード...

public void doGet(HttpServletRequest req, HttpServletResponse resp) {
    res.setContentType("json");
    PrintWriter pw = new PrintWriter(res.getOutputStream());
    if (response != null) pw.println("[{'batchId':'2001','batchRef':'146'}]");
    pw.close();
}

HtmLコード...

    <div id="gridDD" dojoType="dojox.grid.DataGrid" 
    jsId="gridDD" style="height: 600x; width: 100%;" 
    store="ddInfo" structure="layoutHtmlTableDDDeltaSets">
    </div>      

    var rawdataDDInfo = ""; // empty at start
    ddInfo = new dojo.data.ItemFileWriteStore({
        data: {
            identifier: 'batchId',
            label: 'batchId',
            items: rawdataDDInfo
        }
    });
    <script>
    function doSelectBatchsAfterDate() {
    var xhrArgs = {
        url: "../secure/jsonServlet",
        handleAs: "json",
        preventCache: true,
        load: function(data) {
        var xx =dojo.toJson(data);
            var ddInfoX = new dojo.data.ItemFileWriteStore({data: xx});
            dijit.byId('gridDD').setStore(ddInfoX);
        },
        error: function(error) {
                alert("error:" + error);
        }
    }

    //Call the asynchronous xhrGet
    var deferred = dojo.xhrGet(xhrArgs);
    }
    </script>
<img src="go.gif" onclick="doSelectBatchsAfterDate();"/>
4

1 に答える 1

0

dojo.data.ItemFileWriteStoreサーバーから返されたJSONデータを使用して作成する場合。アイテムを提供するだけで、メタデータを指定する必要があります。正しいコードは次のようになります。

var ddInfoX = new dojo.data.ItemFileWriteStore({
    data: {
        identifier: 'batchId',
        label: 'batchId',
        items: xx
    }
});

dojo.toJsonまた、JSONオブジェクトをJSON文字列に変換する関数は必要ありません。にはdojo.data.ItemFileWriteStore、JSON文字列ではなく、パラメータとしてJSONオブジェクトが必要です。

于 2010-05-31T01:11:41.623 に答える