0

Rails 3.0.6 で ExtJS を使用しています。フォームとグリッド パネルがあります。たとえば、フォームには顧客の詳細があり、グリッドには特定の顧客が購入した製品の詳細が含まれています (一対多)。

データ全体 (フォーム + グリッド) を 2 つの json ストアではなく単一の json ストアとして送信する方法を提案できますか?

前もって感謝します !

4

1 に答える 1

0

新しい 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'));
            });
        });
    }
});
于 2011-04-28T04:40:50.823 に答える