Backbone.Collection.reset() 在 IE8 中抛出异常



每次,我都会在Backbone.Marionette.CollectionView中重置Backbone.Collection,IE8都会抛出一个错误:

Function.prototype.apply:参数为空或未定义

同样的情况也适用于空视图。

我的 CoffeeScript 代码(下面的 js 版本):

Collection = Backbone.Collection.extend
url       : '/videos.json'
baseModels: []
initialize : -> 
  GIS.VL.vent.on 'specialization:selected', @onSpecializationSelected, @
  @on 'reset', @onFirstSync, @
onFirstSync : (a)->
  @off 'reset', @onFirstSync, @
  @baseModels = @models
  console.log @models
onSpecializationSelected : (model)-> 
  if model.id < 0
    @reset @baseModels
  else
    filteredItems = _.filter @baseModels, (item)->
      specializations = _.map item.get('specializations'), (specialization) ->
        specialization.id 
      -1 < _.lastIndexOf specializations, model.id
    @reset filteredItems

Javascript版本:

var Collection;
Collection = Backbone.Collection.extend({
  url: '/videos.json',
  baseModels: [],
  initialize: function() {
    GIS.VL.vent.on('specialization:selected', this.onSpecializationSelected, this);
    return this.on('reset', this.onFirstSync, this);
  },
  onFirstSync: function(a) {
    this.off('reset', this.onFirstSync, this);
    this.baseModels = this.models;
    return console.log(this.models);
  },
  onSpecializationSelected: function(model) {
    var filteredItems;
    if (model.id < 0) {
      return this.reset(this.baseModels);
    } else {
      filteredItems = _.filter(this.baseModels, function(item) {
        var specializations;
        specializations = _.map(item.get('specializations'), function(specialization) {
          return specialization.id;
        });
        return -1 < _.lastIndexOf(specializations, model.id);
      });
      return this.reset(filteredItems);
    }
  }
});

我正在使用简单的收藏视图,带有车把模板:

  VideosView = Backbone.Marionette.CollectionView.extend
    tagName   : 'div'
    itemView  : VideoView
    collection: new Collection
    config: 
      itemsPerPage: 3
    initialize: (options)->
      console.log 'initialize'
      # override defaults:
      @config           = _.extend @config, options

下面是Javascript版本:

var VideosView;
VideosView = Backbone.Marionette.CollectionView.extend({
  tagName: 'div',
  itemView: VideoView,
  collection: new Collection,
  config: {
    itemsPerPage: 3
  },
  initialize: function(options) {
    console.log('initialize');
    return this.config = _.extend(this.config, options);
  }
});

这原来是木偶中的一个错误,使用 null 或未定义的 arguments 参数调用.apply

木偶及其依赖项已更新以解决此问题,并且该修复程序不在开发分支中(请参阅此票证:https://github.com/marionettejs/backbone.marionette/issues/368)。

如果您立即需要此修复程序,则需要从dev分支中获取木偶构建:https://github.com/marionettejs/backbone.marionette/tree/dev/lib

如果您使用的是"核心"版本,请务必同时更新 Wreqr 和 EventBinder。保姆不需要任何更新。

确保所有对象都没有杂散逗号:

ie8err: { something: 1, something: 2, } //Error in IE8 and below.

我不是肯定的,但它闻起来可能是。

最新更新