如何将参数传递给主干牵线木偶复合视图模板

时间:2013-01-18 18:48:39

标签: backbone.js marionette

有没有办法将参数输入到牵线木偶复合视图模板中?我认为我初始化视图的任何参数都可以在模板中使用,但它似乎不起作用。

Views.myView = Marionette.CompositeView.extend({
  template: '#myView',
  otherstuff...
});


var collection = new App.Collection(); 
App.main.show(new Views.myView({
  collection: collection,
  isMine: true
}));

模板:

<%= isMine %> 

当呈现模板时isMine未定义:

3 个答案:

答案 0 :(得分:17)

您可以使用templateHelpers函数。例如,我有一个在渲染时填充不同区域的布局。

onRender: function () {
            var contactInfo = this.model.get('contactInfo');

            this.contactInfoRegion.show(new ContactInfoView(
                {
                    model: contactInfo,
                    travelerNumber: this.travelerNumber,
                    numberOfTravelers: this.numberOfTravelers
                }
            ));
}

var ContactInfoView = Backbone.Marionette.ItemView.extend({
        model: ContactInfoModel,
        template: Backbone.Marionette.TemplateCache.get(contactInfoTemplate),
        templateHelpers:function(){

            return {
                numberOfTravelers: this.options.numberOfTravelers,
                travelerNumber: this.options.travelerNumber
            }
        }
    });

答案 1 :(得分:6)

在freenode聊天室中得到brian-mann的帮助来解决这个问题。我将值传递给视图,但我需要通过覆盖serializeData方法将其作为属性发送到实际模板。

我也检查将默认值设置为true,因此如果我不想,我不必传入值。

Views.myView = Marionette.CompositeView.extend({
  template: '#myView',
  serializeData: function() {
      var viewData = {};
      viewData.isMine = this.options.isMine === undefined ? true : this.options.isMine;
      return viewData;
    },
  otherstuff...
});

答案 2 :(得分:-2)

您可以设置视图模型的模型属性:{isMine:true}&#39;