2013-11-25 55 views
0

我有一個嵌套的對象列表,並且在定位單個對象時遇到了問題。我有一個Items,其中每個有很多Options。現在一個動作被我的(打算)奇異的OptionController捕捉到,但是所有的選項都會有變化。在一組對象中處理單個對象動作?

那麼,我該如何針對一個選項?

樣品jsBin:http://jsbin.com/ONAsIpa/4/edit

模板:

<script type="text/x-handlebars" data-template-name="application"> 
    <p><strong>Ember.js example:</strong><br> Finally, a dashboard that monitors 'items', & their child 'options'!!</p> 
    {{outlet}} 
    </script> 

    <script type="text/x-handlebars" data-template-name="items"> 
    <h2>Items:</h2> 
    <dl> 
     {{#each}} 
     <dt>Item: {{title}}</dt> 
     <dd>Cost: {{cost}}</dd> 

     <dd class='options'>{{render 'options' options}}</dd> 
     {{/each}} 
    </dl> 
    </script> 

    <script type="text/x-handlebars" data-template-name="options"> 
    <dl> 
     {{#each option in controller }} 
     {{render option}} 
     {{/each}} 
    </dl> 
    </script> 

    <script type="text/x-handlebars" data-template-name="option"> 
     <dt>Option cost: {{option.cost}}</dt> 
     <dd {{bindAttr class=":opt-btn isSelected"}}{{action 'toggleOption'}}>Pick Me!</dd> 
    </script> 

灰燼對象:

App = Ember.Application.create(); 

/**** ROUTES ****/ 
App.Router.map(function() { 
    this.resource('items'); 
}); 
App.IndexRoute = Ember.Route.extend({ 
    redirect: function() { 
    this.transitionTo('items'); 
    } 
}); 
App.ItemsRoute = Ember.Route.extend({ 
    model: function() { 
    var a = Em.A(); 
    a.pushObject(App.Item.create({title: 'A', cost: '100', options: buildMockOptions('A')})); 
    a.pushObject(App.Item.create({title: 'B', cost: '200', options: buildMockOptions('B')})); 
    a.pushObject(App.Item.create({title: 'C', cost: '300', options: buildMockOptions('C')})); 
    return a; 
    } 
}); 

buildMockOptions = function(someVar){ 
    var arr = []; 
    for(var i = 0;i<3;i++){ 
    var opt = App.Option.create({someOption: 'Option for ' + someVar + ': ' + i}); 
    opt.cost = 5*i; 
    arr.pushObject(opt); 
    } 
    return arr; 
}; 

/**** MODELS ****/ 
App.Item = Ember.Object.extend({ 
    title: '', 
    cost: '', 
    quantity: '', 
    options: null, 

    totalOptionsCost: function(){ 
    var j = this.get('options').reduce(
     function(prevValue, currentValue, index, array){ 
     return prevValue + parseInt(currentValue.get('cost'), 10); }, 0); 
    return j; 
    }.property('[email protected]') 
}); 

App.Option = Ember.Object.extend({ 
    someOption: '', 
    cost: '' 
}); 


/**** CONTROLLERS ****/ 
App.ItemsController = Ember.ArrayController.extend({ 

    totalOptions: function(){ 
    var opts = this.mapBy('options'); 
    return [].concat.apply([], opts).length; 
    }.property(), 

    totalOptionCost: function(){ 
    var sum = this.reduce(function(prev, curr){ 
     return prev + curr.get('totalOptionsCost');},0); 
    return sum; 
    }.property('@each.totalOptionsCost'), 

    actions: { 
    toggleOption: function(opt) { 
     alert('ItemsController caught action'); 
    } 
    } 
}); 

App.OptionController = Ember.Controller.extend({ 
    actions: { 
    toggleOption: function(opt) { 
     this.set('isSelected', !this.get('isSelected')); 
     alert('OptionController caught action'); 
    } 
    } 
}); 

回答

1

選項控制器不通過模型的支持(因爲它是擴展控制R)。這幾乎就好像這是一個部分轉換。所以這主要是一個範圍問題。

App.OptionController = Ember.ObjectController.extend({ 

{{render 'option' option}} 

{{cost}} instead of {{option.cost}} 

http://jsbin.com/OjOvarE/1/edit