我正在使用带有 Rails 3.0.6 的 ExtJS。我有一个表格和一个网格面板。例如,表单包含客户详细信息,网格包含特定客户购买的产品详细信息(一对多)。
谁能建议如何将整个数据(表单+网格)作为单个 json 存储而不是 2 个 json 存储发送?
提前致谢 !
新的 Ext JS 4 具有可以解决问题的模型关联 ( http://docs.sencha.com/ext-js/4-0/guide/data )
// each User hasMany Orders
Ext.define('User', {
extend: 'Ext.data.Model',
fields: ['id', 'name', 'email'],
proxy : {
type: 'rest',
url : '/users',
reader: 'json'
},
hasMany: 'Orders'
});
// each Order belongsTo a User, and hasMany OrderItems
Ext.define('Order', {
extend: 'Ext.data.Model',
fields: ['id', 'user_id', 'status'],
belongsTo: 'User',
hasMany: 'OrderItems'
});
// each OrderItem belongsTo an Order
Ext.define('OrderItem', {
extend: 'Ext.data.Model',
fields: ['id', 'order_id', 'name', 'description', 'price', 'quantity'],
belongsTo: 'Order'
});
调用 user.orders() 返回一个配置了 Orders 模型的 Store,因为 User 模型定义了 hasMany: 'Orders' 的关联。
User.load(123, {
success: function(user) {
//we can iterate over the orders easily using the Associations API
user.orders().each(function(order) {
console.log(order.get('status'));
//we can even iterate over each Order's OrderItems:
order.orderItems().each(function(orderItem) {
console.log(orderItem.get('title'));
});
});
}
});