2

こんにちは、Extjs 4.2 データ グリッドを使用しています。「ストア」を json 配列に変換し、それをサーバー側 (つまり Java) に送信する必要があります。

これが私のモデルです。

Ext.define('Writer.Document',{
    extend: 'Ext.data.Model',
    fields: ['id', 'name', 'notes', 'Type', 'date']
});

そして私のストア(オブジェクトのリストを含む)は

var store = Ext.create('Ext.data.Store', {
model: 'Writer.Document',
autoLoad: true,
proxy: {
    type: 'ajax',            
    url : 'findPatientRecordAction',
    reader: {
        type: 'json',
        successProperty: 'success',
        root: 'prognosis',
        messageProperty: 'message'
    }                       
    fields: ['id','name', 'date', 'notes' , 'Type'],
},
});

したがって、一度にグリッドに値を送信している間、サーバー側に ist オブジェクトが必要です。したがって、クライアント側から JSON 配列を送信する必要があります。

私のストアからJSONArrayオブジェクトを作成してサーバー側に送信する方法を教えてください。

よろしく:開発

4

1 に答える 1

5

必要なことを行う方法の簡単な例を次に示します。

function sendGridData(){

    var sendDataArray = [];
    store.each(function(record){
        var recordArray = [
            record.get("id"),
            record.get("name"),
            record.get("date"),
            record.get("notes"),
            record.get("Type")
        ];
        sendDataArray.push(recordArray);
    });

    Ext.Ajax.request({
        url: "your_url_here.jsp",
        success: function(response, opts){
            //?
        },
        failure: function(response, opts) {
            alert("server-side failure with status code " + response.status);
        },
        params: {
            grid_data: Ext.encode(sendDataArray);
        }
    });
}
于 2013-05-03T19:03:00.460 に答える