3

好的,我有一个像这张图片中的布局:

布局

屏幕上部的表格由以下人员组成:

消息列表视图

define(['backbone','collections/messages','views/message'], function(Backbone, MessageCollection, MessageView) {
    var MessageListView = Backbone.View.extend({
        el: '#messagesContainer', 
        initialize: function() {

            this.collection = new MessageCollection();
            this.collection.fetch({reset:true});
            this.listenTo( this.collection, 'reset', this.render );

            this.table = this.$el.find("table tbody");
            this.render();
        },
        render: function() {
            this.collection.each( function(message, index) {                
                this.renderMessage(message, index);
            }, this);
        },
        renderMessage: function(message, index) {
            var view = new MessageView({
                model:message,
                className: (index % 2 == 0) ? "even" : "odd"    
            });
            this.table.append( view.render().el );
        }
    });
    return MessageListView;
});

消息视图

define(['backbone','models/message'], function(Backbone, MessageCollection, MessageView) {
    var MessageView = Backbone.View.extend({
        template: _.template( $("#messageTemplate").html() ), 
        render: function() {
            this.setElement( this.template(this.model.toJSON()) );          
            return this;
        },
        events:{
            'click':'select'
        },
        select: function() {
           // WHAT TO DO HERE?
        }
    });
    return MessageView;
});

应用视图

define(['backbone','views/messages'], function(Backbone, MessageList) {
    var App = Backbone.View.extend({
        initialize: function() {
            new MessageList(); 
        }
    });
    return App;
});

我很快会在屏幕下方添加一个新视图(可能是“PreviewView”)。

当用户单击一行时,我想在“PreviewView”内发生一些事情。

例如,在 PreviewView 中显示其他模型的属性(例如细节)可能会很有趣。

最佳做法是什么?

  • 在每个 MessageView 中保存对 PreviewView 的引用?
  • 在 select 方法中触发事件,并在预览视图中使用on()监听它们。
  • 在我的模型中使用瞬态“选定”属性,并使 PreviewView 监听集合“更改”事件?

谢谢,如果您需要更多详细信息,请告诉我,我将编辑问题。

4

1 回答 1

6

不确定最佳实践,但我发现这个解决方案实施起来很简单。我创建了一个全局消息传递对象,总线,无论如何:

window.App = {};
window.App.vent = _.extend({}, Backbone.Events);

您必须在先前创建的事件总线上注册 PreviewView 的“可触发”功能(根据您的示例,这应该在 中PreviewView):

initialize: function () {
    App.vent.on('PreviewView.show', this.show, this);
}

现在您应该能够通过调用从应用程序中的任何位置触发任何已注册的事件:App.vent.trigger. 例如,当用户单击一行时,您将看到类似的内容:

App.vent.trigger('PreviewView.show');

如果您必须与触发的事件一起发送和反对,请使用:

App.vent.trigger('PreviewView.show', data);
于 2013-07-11T09:41:34.397 回答