2013-05-10 100 views
2

使用ExtJS的4.2 MVC模式ExtJS的4.2擴展使用自定義模式MVC問題

我試圖創建一個自定義模式,儲存,代理,讀者,作家,但我有得到它的MVC模式的工作問題。我跟着this example來擴展一個模型,我可以看到它的工作,只有當它沒有在MVC方式使用。

我的商店引用了模型,例如在模型屬性中定義的聯繫人,然後Contacts使用模型屬性引用自定義模型WakandaModel。但是,當我創建指向「聯繫人」的商店時,自定義WakandaModel中定義的模型屬性或代理都不會被引入商店模型。

這是我的代碼,我留下了評論,所以你可以看到我試圖嘗試。謝謝你的幫助!

應用程序代碼

Ext.Loader.setConfig({ 
    enabled : true, 
    paths : { 
     'Ext.ux' : "lib/extux", 
     'Wakanda' : "lib/extux/wakanda" 
    } 
}); 
Ext.application({ 
    name : 'SimplyFundraising', 
    autoCreateViewport : true, 

    requires : ['Ext.ux.Router', // Require the UX 
    'Ext.window.MessageBox'], 

    controllers : ['Contacts'], 
}); 

定製型號

Ext.define('Wakanda.Model', { 

    extend: 'Ext.data.Model', 

    idProperty: '__KEY', 

    stampProperty: '__STAMP', 

    defaultProxyType: 'wakanda', 

    onClassExtended: function(cls, data) { 
      // debugger; 
     // cls.apply(this) 
//  var parts = data.$className.split('.'); 
//  var entity = parts[2] 
//  var catalog = this.prototype.getCatalog(entity), 
//   attributes = catalog.attributes; 
//  for (var i = 0, l = attributes.length; i < l; i++) { 
//   if (attributes[i].name === 'ID') { 
//    attributes[i].persist = false; 
//   } 
//  } 
//  attributes.push({name: this.prototype.idProperty}); 
//  attributes.push({name: this.prototype.stampProperty}); 
//  // data.fields = attributes; 
//  // debugger; 
//  //this.setFields(data.fields) 
//  // var mymodel = Ext.ModelManager.getModel(data.$className); 
    // debugger; 
     // Ext.appy(this); 
//  //this.superclass.superclass.$onExtended.apply(this, arguments); 
    }, 

    getCatalog: function(className) { 
     var catalog; 
     Ext.Ajax.request({ 
      async: false, 
      url: 'http://127.0.0.1:8081/cors/$catalog/' + className, 
      success: function(response) { 
       catalog = Ext.decode(response.responseText); 
      } 
     }); 
     return catalog; 
    } 

}); 

自定義代理

Ext.define('Wakanda.Proxy', { 

    extend: 'Ext.data.proxy.Rest', 

    // alternateClassName: 'SimplyFundraising.data.WakandaProxy', 

    alias : 'proxy.wakanda', 

    sortParam: '$orderby', 

    filterParam: '$filter', 

    startParam: '$skip', 

    limitParam: '$top', 

    // groupersParam: '$group', 

    reader: 'wakanda', 

    writer: 'wakanda', 

    actionMethods: { 
     create : 'POST', 
     read : 'GET', 
     update : 'POST', 
     destroy: 'POST' 
    }, 

    buildUrl: function(request) { 
     debugger; 
     var modelName = this.model.modelName, 
      operation = request.operation, 
      records = operation.records || [], 
      record = records[0], 
      id = record ? record.getId() : operation.id, 
      url = '/cors/' + modelName, 
      action = request.action; 

     if (this.appendId && id && (action === 'read' || action === 'destroy')) { 
      url += '(' + id + ')'; 
     } 

     request.url = url; 

     // console.log("buildUrl", this, arguments, request.url); 


     if (action !== 'read') { 
      if (action === 'create') action = 'update'; 
      else if (action === 'destroy') action = 'delete'; 
      url = Ext.urlAppend(url, '$method=' + action); 
     } 

     if (this.noCache) { 
      url = Ext.urlAppend(url, Ext.String.format("{0}={1}", this.cacheString, Ext.Date.now())); 
     } 

     return url; 
    }, 

    encodeSorters: function(sorters) { 
     var min = [], 
      length = sorters.length, 
      i = 0, sort = ''; 

     for (; i < length; i++) { 
      sort += sorters[i].property + ' ' + sorters[i].direction + ' '; 
     } 

     return sort; 
    }, 

    encodeFilters: function(filters) { 
     var min = [], 
      length = filters.length, 
      i = 0, filter = ''; 

     for (; i < length; i++) { 
      filter += filters[i].property + ' eq ' + filters[i].value + '@ '; 
     } 
     return filter; 
    } 

}); 

定製閱讀器

Ext.define('Wakanda.reader', { 

    extend: 'Ext.data.reader.Json', 

    //alternateClassName: 'SimplyFundraising.data.WakandaReader', 

    alias : 'reader.wakanda', 

    root: '__ENTITIES', 

    totalProperty: '__COUNT', 

    getData: function(data) { 
     if (Ext.isObject(data) && !data[this.root]) { 
      data = [data]; 
     } 
     return data; 
    } 

}); 

自作家

Ext.define('Wakanda.writer', { 

    extend: 'Ext.data.writer.Json', 

    // alternateClassName: 'SimplyFundraising.data.WakandaWriter', 

    alias: 'writer.wakanda', 

    writeAllFields: false, 

    getRecordData: function(record) { 
     var isPhantom = record.phantom === true, 
      writeAll = this.writeAllFields || isPhantom, 
      nameProperty = this.nameProperty, 
      fields = record.fields, 
      data = {}, 
      changes, 
      name, 
      field, 
      key; 

     if (writeAll) { 
      // console.log("getRecordData1", this, arguments); 
      fields.each(function(field){ 
       if (field.persist) { 
        name = field[nameProperty] || field.name; 
        data[name] = record.get(field.name); 
       } else { 

       } 
      }); 
     } else { 
      changes = record.getChanges(); 
      // console.log("getRecordData2", this, arguments, changes); 
      for (key in changes) { 
       if (changes.hasOwnProperty(key)) { 
        field = fields.get(key); 
        name = field[nameProperty] || field.name; 
        data[name] = changes[key]; 
       } 
      } 
      if (!isPhantom) { 
       data[record.idProperty] = record.getId(); 
       data[record.stampProperty] = record.get(record.stampProperty); 
      } 
     } 
     return {'__ENTITIES': [data]}; 
    } 

}); 

錄模型

Ext.define('SimplyFundraising.model.Contact', { 
    extend : 'Wakanda.Model' , 
    //constructor: function() { 
     //alert(「Going to call parent’s overriden constructor…」); 
    // this.callParent(arguments); 
     // return this; 
    // } 
}); 

聯繫人存儲

Ext.define('SimplyFundraising.store.Contacts', { 
    extend : 'Ext.data.Store', 
    model : 'SimplyFundraising.model.Contact', 
    autoLoad : true, 
    autoSync : true, 
    // constructor: function() { 
      // this.model = Ext.create('SimplyFundraising.model.Contact') 

      //alert(「Going to call parent’s overriden constructor…」); 
     // this.callParent(arguments); 
     return this; 
    // } 
}); 

聯繫控制器

Ext.define('SimplyFundraising.controller.Contacts', { 
    extend : 'Ext.app.Controller', 
    models : ['Contact'], 


    views : ['contacts.List', 'contacts.Edit'], 
    init : function() { 
     this.control({ 
      'contactslist' : { 
       itemdblclick : this.editContact, 
       removeitem : this.removeContact 
      }, 
      'contactslist > toolbar > button[action=create]' : { 
       click : this.onCreateContact 
      }, 
      // 'contactsadd button[action=save]': { 
      // click: this.doCreateContact 
      // }, 
      'contactsedit button[action=save]' : { 
       click : this.updateContact 
      } 
     }); 
    }, 
    list : function() { 
     // var mystore = Ext.StoreMgr.lookup('Contacts'); 
    // var myContact = this.getModel('Contact') 
    // var User = this.getModel('User'); 

     //debugger; 
     // var mystore = Ext.create('SimplyFundraising.store.Contacts') 

     // var myContact = this.getModel('Contact').create() 
    // var bb = myContact.create() 

     // var rr = Ext.create('SimplyFundraising.model.Contact') 
     var mystore = Ext.create('SimplyFundraising.store.Contacts') 
     debugger; 
      // mystore.proxy.api.read = users.proxy.api.read + '(17)' 
     //mystore.proxy.extraParams = { $expand: 'ContactType'}; 
     mystore.load(); 
     //var test = Ext.ModelManager.getModel('Contact'); 

     // //var User = this.getContactModel(); 
     // User.load(258, { 
    // success: function(user) { 
     // console.log("Loaded user 258: " + user.get('lastName')); 
    // } 
// }); 
    }, 
    editContact : function(grid, record) { 
     var view = Ext.widget('contactsedit'); 
     view.down('form').loadRecord(record); 
     this.addnew = false 
    }, 
    removeContact : function(Contact) { 
     Ext.Msg.confirm('Remove Contact ' + Contact.data.lastName, 'Are you sure?', function(button) { 
      if (button == 'yes') { 
       this.getContactsStore().remove(Contact); 
      } 
     }, this); 
    }, 
    onCreateContact : function() { 
     var view = Ext.widget('contactsedit'); 
     this.addnew = true 
    }, 
    // doCreateContact: function (button) { 
    // var win = button.up('window'), 
    // form = win.down('form'), 
    // values = form.getValues(), 
    // store = this.getContactsStore(); 
    // if (form.getForm().isValid()) { 
    // store.add(values); 
    // win.close(); 
    // } 
    // }, 
    updateContact : function(button) { 
     var win = button.up('window'), form = win.down('form'), record = form.getRecord(), values = form.getValues(), store = this.getContactsStore(); 
     if (form.getForm().isValid()) { 
      if (this.addnew == true) { 
       store.add(values); 
      } else { 
       record.set(values); 
      } 
      win.close(); 
     } 
    } 
}); 

回答

0

我得到這個工作現在:

它看起來像我的自定義wakanda模型,代理,閱讀器,作家不加載。關於MVC如何引用類並加載文件和實例化類仍然有點困惑,我在其他問題中提出了這個問題。

任何方式修復被添加需要的定製wakanda模式和代理

對於Wakanda模型添加要求:['Wakanda.proxy']
對於Wakanda代理添加要求:['Wakanda.reader', 'Wakanda.writer']

現在繼承按預期工作。