質問

サーブレットからのデータを使用して、Dojo dojox.grid.datagridをhavaにしたいと思います。

問題:サーブレットから返されるデータは表示されません。「ごめんなさい、エラーが発生した」というメッセージだけです。

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();"/>
役に立ちましたか?

解決

あなたが作成するとき 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オブジェクトが必要です。

ライセンス: CC-BY-SA帰属
所属していません StackOverflow
scroll top