1

ExtJS と Java の間の通信を阻害しようとしています。ExtJS から netty を使用している Java サーバーにリクエストを送信しています。Java側から応答をフォーマットする方法と、ExtJS側から応答データを読み取る方法の例を誰かが送ってくれたら、感謝します。これはExtJS側からの私のソースです

var store = new Ext.data.JsonStore({
    autoload: true,
    baseParams: {
        conid : '6b09477f-aa04-4f5a-b969-05277d01f07e'
    },
    root: 'OpenCashTime',
    proxy: new Ext.data.ScriptTagProxy({
        url: 'http://localhost:8080/getOpenCash?'
    }),
    fields: [{name: 'Time', mapping: 'Time', type: 'int'}]                  
});
store.load();
store.on('load', function() {
    alert(store.getTotalCount());                   
});
store.on('write', function() {                  
    alert(store.getTotalCount());
});
store.on('loadexception', function() {
    alert("AAAAAA");
});
store.on('metachange', function() {
    //alert(store.getTotalCount());
});
store.on('update', function() {
    //alert(store.getTotalCount());
});
store.on('save', function() {
    //alert(store.getTotalCount());
});
store.on('datachanged', function() {
    //alert(store.getTotalCount());
});

このコードを実行してこの応答を受け取ると {"OpenCashTime":[{"Time":1291623637000},{"Time":1294914317000}]}

4

2 に答える 2

2

タイトルから、データをJsonStoreにロードする場合、レコードとしてロードされるJSONオブジェクトの配列を格納するプロパティを持つ有効なJson文字列が必要です。rootプロパティ名は、JsonStoreを構成するときにプロパティによって設定されます。

このように保存します。

{
  xtype: 'jsonstore',
  root: 'data',
  idProperty: 'ID',
  fields: [
    {name: 'ID', mapping: 'ID', type: 'int'}
    {name: 'someDate', mapping: 'someDate', type: 'date', dateFormat: 'Y-m-d'}
  ],
  url: 'hereBeYourURl'
}

このようなものを喜んで食べます:

{"data":[{"ID":"1","someDate":"2002-10-02"},{"ID":"2","someDate":"2002-05-22"}]}
于 2011-02-02T16:06:03.950 に答える
1
fields: [{name: 'Time', mapping: 'Time', type: 'int'}]  
fields: [{name: 'Time', type: 'int'}]  

ところで、ID マッピングの場合は省略できます。これら 2 つのケースでは、同じ結果が得られます。

于 2011-02-02T16:57:34.827 に答える