Отображение коллекции Backbone.js в виде списка выбора

Я пытаюсь визуализировать коллекцию Backbone.js как список select , используя шаблон Underscore.js, и список не заполняется. Отображается элемент select , но нет параметров .

Я подтвердил, что могу передавать отдельные свойства в свой шаблон и отображать их как элементы label , поэтому проблема должна заключаться в том, как я пытаюсь обработать коллекцию.

Вот мой код Backbone:

Rate = Backbone.Model.extend({
    duration : null
});

Rates = Backbone.Collection.extend({
    initialize: function (model, options) {
    }
});

AppView = Backbone.View.extend({
    el: $('#rate-editor-container'),
    initialize: function () {
      this.rates = new Rates(null, { view: this } );

      this.rates.add(new Rate ({ duration: "Not Set" }));
      this.rates.add(new Rate ({ duration: "Weekly" }));
      this.rates.add(new Rate ({ duration: "Monthly" }));

      this.render();
    },
    render: function() {
      var rate_select_template = _.template($("#rate_select_template").html(), {rates: this.rates, labelValue: 'Something' });
      $('#rate-editor-container').html(rate_select_template);
    },
});

var appview = new AppView();

И мой шаблон:

<script type="text/template" id="rate_select_template">
  <select id="rate-selector"></select>
  <% _(rates).each(function(rate) { %>
    <option value="<%= rate.duration %>"><%= rate.duration %></option>
  <% }); %>
</script>

<div id="rate-editor-container"></div>

Есть предложения?

16
задан Joshua Taylor 30 September 2015 в 14:23
поделиться