1

指定された形式で JSON を生成する外部ソースがあります。そのデータにアクセスするには、ScriptTagProxy を使用する必要があります。データのフォーマットは (2 つのレコード):

{
"COLUMNS":["KEDBID","EMPID","KE","SOLUTION","ATTACH_KE","ATTACH_SOLUTION"],
"DATA":[
[1,36661,"While adding a new user, if his\/her profile is missing, it could be LDAP    server issue.","Contact Mr. ABC from infra team to get user's profile corrected on server","screenshots.jpg","conacts.doc"],
[2,36661,"The error code # 123445 is trivial that may occur at particular time.","To resolve this issue, we will need to ask DBA team to refresh database. That will fix this type of errors","NA","NA"]
]
} 

このデータの jsonreader を定義する方法は? 私が見たように、ルートは次のようになるはずです:

{ROOT: [ {field1:data1,field2:data1},{field1:data2,field2:data2}]}

私のJSONは次のようなものですが:

{fieldnames:['field1','field2'],
 ROOT:[ [data1ForField1,data1ForField2],[data2ForField1,data2ForField2] ]
}

アップデート

もう 1 つのケースを追加します。同様に、jsonreader を使用できます。

    {"ROWCOUNT":8,
"COLUMNS":["CATID","CATEGORY"],
"DATA":{"CATID":[1,2,3,4,5,6,7,8],"CATEGORY":["Optimization","Automation","Process Improvement","Tool","Other","Another One","ThisHas'","More^!@#(){}"]}} 

ここで、1-->最適化、2-->自動化、3-->プロセス改善など。

基本的に、クエリ オブジェクトをシリアライズして、ColdFusion クエリ オブジェクトからデータを返す必要があります。CF クエリでのシリアル化は、上記の 2 つの形式でデータを返すことができます。

Ext Worldはまだ初心者です!! 何らかのサポートが得られることを願っています。

宜しくお願いします、 Tushar Saxena


以下は、私が問題に直面しているコードです。データは ComBox で利用できるようにストアにアップされています..しかし、各関数または他の手段を使用してデータを読み取ることができませんか? ストア内のデータはコンポーネントにしか供給できないということですか? 別の例では、loadDATA() を使用して手動でデータを一時保存した simplestore (ArrayStore) を作成しました。そこでは、各関数が機能していました!!!

以下のケースでは、ロード後に ADD() を使用して 1 つのレコードを追加すると、各関数が 1 回実行され、追加したばかりのデータが表示されます...そして、追加したばかりのデータはコンポーネントで使用できません!!! どうして!!!

私はまだEXTに慣れていないため、非常に基本的な概念が欠けている可能性があります。

対応は本当に助かります。

var proxy = new Ext.data.ScriptTagProxy({
            url: 'http://127.0.0.1:8500/extex/kebyid.cfm',
            method: 'POST'
        });

        var rec = Ext.data.Record.create([
            {name: 'EMPID', mapping: 1},
                     {name: 'KE', mapping: 2},
                     {name: 'SOLUTION', mapping: 3},
                     {name: 'ATTACH_KE', mapping: 4},
                     {name: 'ATTACH_SOLUTION', mapping: 5}
        ]);

        var myReader = new Ext.data.ArrayReader({
                    idIndex: 0,
                    root: 'DATA'
                }, rec);



        var store = new Ext.data.ArrayStore({
                 proxy: new Ext.data.HttpProxy({
                        url: '/extex/kebyid.cfm',
                            method: 'POST'
                }),

                autoSave: true,
                autoLoad: true,
                root: 'DATA',
                fields: [
                     {name: 'KEID', mapping: 0},
                     {name: 'EMPID', mapping: 1},
                     {name: 'KE', mapping: 2},
                     {name: 'SOLUTION', mapping: 3},
                     {name: 'ATTACH_KE', mapping: 4},
                     {name: 'ATTACH_SOLUTION', mapping: 5}
                ]
            });


    store.each(function(){
        alert('!!!!'); //**************NOT WORKING
    });
    var catCB = new Ext.form.ComboBox({
            fieldLabel: 'Category',
            layout:'absolute',
            x: 100,
             y: 5,
            store: store, //************* DATA IS THERE AS STORE IS PROVIDING DATA TO COMBOBOX
            emptyText:'Select Category...',
            valueField : 'KEID',
            displayField : 'KE',
            hiddenName : 'category',
            hiddenvalue : 'None', 
            mode: 'local',
            editable : false,
            lastQuery: '',
            renderTo: Ext.get("d1"),
            listeners: {

                'beforequery': function(qe){
                      qe.forceAll = true;
                }}
        });
4

1 に答える 1

1

まず、サーバーの出力を scriptTagProxy に使用することはできません。scriptTagProxy はJSONP テクノロジーを利用します。したがって、出力は次のようになります。

callback({
  "COLUMNS":["KEDBID","EMPID","KE","SOLUTION","ATTACH_KE","ATTACH_SOLUTION"],
  "DATA":[
    [1,36661,"While adding a new user, if his\/her profile is missing, it could be LDAP    server issue.","Contact Mr. ABC from infra team to get user's profile corrected on server","screenshots.jpg","conacts.doc"],
    [2,36661,"The error code # 123445 is trivial that may occur at particular time.","To resolve this issue, we will need to ask DBA team to refresh database. That will fix this type of errors","NA","NA"]
  ]
});

次に、単にArrayStoreストアとして使用します。デフォルトで使用ArrayReaderします:

var store = new Ext.data.ArrayStore({
    proxy: new Ext.data.ScriptTagProxy({
        url: 'http://example.com/get_data.php'
    }),
    root: 'DATA',
    fields: [
       'id',
       // ...,
       // ...,
       // ...
    ]
});

UPDATEルートプロパティとして
使用していることを忘れていました。'DATA'設定を保存するために追加しました。

于 2011-08-02T15:04:13.117 に答える