Backbone.js Fuse.js отображает отфильтрованную коллекцию

Я пытаюсь добавить функцию нечеткого поиска для фильтрации объектов в коллекции. Консоль показывает, что предохранитель работает правильно и возвращает правильные объекты. Теперь вопрос заключается в том, как передать отфильтрованную коллекцию моему представлению для отображения.

Вот коллекция:

define(["jquery", "backbone", "models/MachineModel"],

function($, Backbone, Model) {

var MachineCollection = Backbone.Collection.extend({

  model: Model,
  url: '/api/machines',
  searchablefields: ['name', 'type', 'ips', 'dataset', 'cpus', 'datacenter', 'state'], 

  rebuildIndex: function(options) {
    var _ref;
    if (options == null) {
      options = {
        keys: this.searchablefields
      };
    }
    return this._fuse = new Fuse(_.pluck(this.models, 'attributes'), options);

  },

  search: function(query) {

    this.rebuildIndex();

    var result = this._fuse.search(query);

    console.log(result);

    this.trigger('reset');

  }

});

return MachineCollection;

});

и вот мой взгляд

define(["jquery", "backbone", "views/cloud/machines/SingleMachineView", "text!templates/cloud/machines/allMachines.html"],

function($, Backbone, SingleMachineView, template){

    var AllMachinesView = Backbone.View.extend({

        el: "#magic",

        initialize: function() {
            // Calls the view's render method
            this.collection.on('add', this.addMachine, this);
            this.collection.on('reset', this.onCollectionReset, this);
            this.render();

        },

        // View Event Handlers
        events: {
            'keyup #filter': 'fuzzySearch'
        },

        // SUBVIEWS
        // ========

        onCollectionReset: function(collection) {

            console.log('collection reset');

            var that = this;

            $(collection).each(function (model) {
                that.addMachine(model);
            });
        },

        addMachine: function(model) {

            var machineHTML = (new SingleMachineView({ model: model })).render().el;
            $(machineHTML).prependTo('#machine-container');

        },

        // FUZZY SEARCH
        // ============

        fuzzySearch: function(e) {
            var query = $(e.target).val();
            this.collection.search(query);
        },


        // RENDER
        // ======

        render: function() {

            this.template = _.template(template);

            this.$el.html(this.template);

            return this;

        }

    });

    return AllMachinesView;

 });

Любое понимание будет с благодарностью.

0 ответов

Другие вопросы по тегам