1

YUI を使用してテーブルを表示しようとしています。次の例を使用して

YAHOO.example.Data = {
        bookorders: [
            {id:"po-0167", date:new Date(1980, 2, 24), quantity:1, amount:4, title:"A Book About Nothing"},
            {id:"po-0783", date:new Date("January 3, 1983"), quantity:null, amount:12.12345, title:"The Meaning of Life"},
            {id:"po-0297", date:new Date(1978, 11, 12), quantity:12, amount:1.25, title:"This Book Was Meant to Be Read Aloud"},
            {id:"po-1482", date:new Date("March 11, 1985"), quantity:6, amount:3.5, title:"Read Me Twice"}
        ]
    }

    YAHOO.example.Basic = function() {
        var myColumnDefs = [
            {key:"id", sortable:true, resizeable:true},
            {key:"date", formatter:YAHOO.widget.DataTable.formatDate, sortable:true, sortOptions:{defaultDir:YAHOO.widget.DataTable.CLASS_DESC},resizeable:true},
            {key:"quantity", formatter:YAHOO.widget.DataTable.formatNumber, sortable:true, resizeable:true},
            {key:"amount", formatter:YAHOO.widget.DataTable.formatCurrency, sortable:true, resizeable:true},
            {key:"title", sortable:true, resizeable:true}
        ];

        var myDataSource = new YAHOO.util.DataSource(YAHOO.example.Data.bookorders);
        myDataSource.responseType = YAHOO.util.DataSource.TYPE_JSARRAY;
        myDataSource.responseSchema = {
            fields: ["id","date","quantity","amount","title"]
        };

        var myDataTable = new YAHOO.widget.DataTable("basic",
                myColumnDefs, myDataSource, {caption:"DataTable Caption"});

        return {
            oDS: myDataSource,
            oDT: myDataTable
        };
    }();

bookorders データを使用する代わりに、esri.tasks.QueryTask を使用してデータベースから結果をクエリしました。

そのため、bookorders json 配列に入力するデータを反復処理する必要がありました。

for (var i=0, il=results_books.features.length; i<il; i++) {
     var featureAttributes = results_books.features[i].attributes;
         var string = " id : \"" + results_books.features[i].attributes[0] + "\",";
         var string = string + " date : \"" + results_books.features[i].attributes[1] + "\",";
         var string = string + " quantity: \"" + results_books.features[i].attributes[2] + "\",";
         var string = string + " amount: \"" + results_books.features[i].attributes[3] + "\",";
         var string = string + " title: \"" + results_books.features[i].attributes[4] + "\"";

}

しかし、文字列をJSON配列にプッシュするにはどうすればよいですか?属性を読み取る方法は正しいですか?

EDIT : 文字列にコンマを追加しました

4

1 に答える 1

1

文字列を作成するのではなく、オブジェクト リテラルを使用するだけです。

for (var i=0, il=results_books.features.length; i<il; i++) {
     var featureAttributes = results_books.features[i].attributes;
     var book = {
        "id" : featureAttributes[0],
        "date" : featureAttributes[1],
        "quantity" : featureAttributes[2],
        "amount" : featureAttributes[3],
        "title" : featureAttributes[4]
      };
      // push into array   
}

中間文字列を使用する必要はありません。完全なアウト オブジェクトをすぐに作成できます。

于 2012-09-12T02:40:51.810 に答える