0

我的代码获取文件类型并相应地启动新的 ImageView。

var frameIdRegion = new Marionette.Region({
                    el: '#viewerId'
                });


                // Create a new Backbone Marionette View with item model. Render View and Show it on Screen.
                if(fileType === 'Image'){
                    frameIdRegion.close(imageView);
                    frameIdRegion.reset();
                    var imageView = new ImageView({model: item});                   
                    frameIdRegion.show(imageView);              
                    $(".frameId img").show();
                    $(".frameId img").load(function(){
                        $("#fit_to_screen").trigger('click');
                    });
                    imageView.close();
                }
                else if(fileType === 'pdf'){
                    var objectView = new ObjectView({model: item});
                    frameIdRegion.reset();
                    frameIdRegion.show(objectView);
                    $("#pdf_viewer").show();
                    $('#pdf_viewer').trigger('focus');
                }
                else if(fileType === 'unsupported'){
                    var errorView = new ErrorView({model: item});
                    frameIdRegion.reset();
                    frameIdRegion.show(errorView);
                }

但是当我启动一个新的 ImageView 时,我的 ImageView 旧实例没有被清除。而且我的事件发生了很多次。这是我的 ImageView 代码。

    var ImageView = Marionette.ItemView.extend({
          template: template,
          className: 'frameId',
    onClose: function(){
             this.remove();
          this.unbind();
          this.model.unbind("change", this.modelChanged);
          }
});

请帮助我做错了什么?

4

1 回答 1

0

尝试使用主干listenTo功能。它会附加到任何调用它的东西上,所以当你ItemView被处置时,事件监听器也会如此。

http://backbonejs.org/#Events-listenTo

stopListening如果你真的需要它,它也有一个方法。当您的视图被删除时,它应该自动停止监听所有被调用的东西listenTo

http://backbonejs.org/#View-remove

于 2013-09-13T00:42:00.667 回答