0

次のコードは機能し、必要なことはすべて実行しますが、あまりクリーンではありません。誰かが私の仕事を達成するためのより良い方法を指摘できれば、それは素晴らしいことです. コードにコメントを付けて、より良いと思う理由を説明しました。

このコードは、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 を使用する必要がありますか?

4

1 に答える 1