0

YUI3 sendRequest をデータソースに適用して、プレーン オブジェクトではなく定義済みオブジェクトを返すにはどうすればよいですか?

たとえば、この Base クラスとそのメソッドがあります。

function Student(id, name){
   this.id = id;
   this.name = name;
}
Context.prototype.setId   = function(id){ this.id = id; };
Context.prototype.setName = function(name){ this.name = name; };
Context.prototype.getId   = function(){ return this.id; };
Context.prototype.getName = function(){ return this.name; };

そして、API からデータを取得し、それを正規化し、データをオブジェクトとして返す次のコードがあります。

var studApiDataSource = new Y.DataSource.Get({source: API_URL});

studApiDataSource.plug(Y.Plugin.DataSourceJSONSchema, {
  schema: {
    resultListLocator: "response.student",
    resultFields: ["id","name"]
  }
});

var myCallback = function(e) {
  Y.Array.each(e.response.results, function(stud){
    Y.log(stud.id+' '+stud.name);
  }
}

studApiDataSource.sendRequest({
  request: "?cmd=getStudents",
  callback: {
    success: myCallback,
    failure: function (e) { }
  }
});

stdApiDataSource.sendRequest() によって取得され、myCallback に渡されるオブジェクトの配列は、id プロパティと name プロパティを持つ通常のオブジェクトです。ただし、これらをメンバー関数 (getId、getName など) も備えた Student オブジェクトにしたい

4

1 に答える 1

1

完全に理解しているかどうかはわかりませんが、次のようなことができます。

var studentJSON = "{\"id\": 17, \"name\":\"my name is\"}";
function Student(obj){
  this.name = obj.name;
  this.id = obj.id;
}
Student.prototype.setId   = function(id){ this.id = id; };
Student.prototype.setName = function(name){ this.name = name; };
Student.prototype.getId   = function(){ return this.id; };
Student.prototype.getName = function(){ return this.name; };

YUI().use('json-parse', 'json-stringify', function (Y) {

    try {

        var stud = new Student(Y.JSON.parse(studentJSON));
        alert(stud.getId());
    }
    catch (e) {
        alert(e);
    }

});
于 2011-09-30T23:29:08.170 に答える