次のコードは機能し、必要なことはすべて実行しますが、あまりクリーンではありません。誰かが私の仕事を達成するためのより良い方法を指摘できれば、それは素晴らしいことです. コードにコメントを付けて、より良いと思う理由を説明しました。
このコードは、BuildingRoute のモデルを定義し、サーバーからのデータで更新します。
App.BuildingRoute = Ember.Route.extend({
buildingData : { // Can't I just create the object once my data comes,
name: '', // is it necessary to initialize this object?
addr1: '',
addr2: ''
},
model: function() {
this.getNodeInfo(); // should I be calling the function to access the server here?
return this.buildingData;
},
getNodeInfo: function(){
var _this = this;
var req = {
callback: nodeDataCB,
something: {
method: 'getNode',
uid: 'getNodeData',
nodeId: gVars.node
}
}
Server.getData(req);
function nodeDataCB(data){
console.log($.parseXML(data));
var attributes = $(data).find('attributes');
var addr1 = attributes.find('attr[n="disAddress1"]').html();
var addr2 = attributes.find('attr[n="disAddress2"]').html();
var name = $(data).find('name').text();
Ember.set(_this.buildingData, 'name', name); // must I set the value for each
Ember.set(_this.buildingData, 'addr1', addr1); // specifically, can't i just set
Ember.set(_this.buildingData, 'addr2', addr2); // the whole object at once?
}
}
});
Ember-data を使用する必要がありますか?