如何传递要在子视图中呈现的视图对象?

时间:2012-04-27 15:53:47

标签: ember.js

我正在尝试使用它自己的模板和CSS构建一个可重用的弹出视图。在这个可重用的视图中,我希望能够显示包含父视图要放入弹出窗口的内容的子视图。

弹出窗口的把手模板如下所示:

<div class='popup'>
    <a class='open' href='#' {{action toggleVisible}}>
        {{view button}}
    </a>

    <div class='collapse'>
        <div class='box'>
            <div class='arrow'></div>
            <div class='arrow-border'></div>

            {{view content}}

        </div>
    </div>
</div>

在此上下文中,buttoncontent应该是在此弹出窗口中呈现的Ember视图,并且这些视图将根据父视图创建和显示弹出窗口而有所不同。

弹出View对象如下所示:

var popup = Ember.View.extend({
    button: null,
    content: null,
    templateName: 'popbox',
    visible: false,
    toggleVisible: function() {
        var visible = this.get('visible');
        this.set('visible', !visible);
        if (visible) {
            this.$().find('.box').fadeOut(250);
        } else {
            var pop = this.$().find('.popbox');
            var box = this.$().find('.box');
                box.css({
                    'display': 'block',
                    'top': 10,
                    'left': ((pop.parent().width()/2) -box.width()/2 )
                    });
            }
        }
    }
}));

我不确定如何从父视图传递要在弹出窗口中呈现的模板。现在我正在尝试这样做,但它不起作用。

var sendto = Ember.View.extend({
    templateName: 'sendto',
    popupView: popup.extend({
        button: Ember.View.extend({
            template: Ember.Handlebars.compile('{{model.selectedRecipients.length}} {{model.peopleOrPersonText}}')}),
        content: Ember.View.extend({template: Ember.Handlebars.compile('Test content')})
    })
}));

将视图传递给弹出视图的正确方法是什么?

注意:这似乎有效,但它会生成DEPRECATED错误消息:

Something you did caused a view to re-render after it rendered but before it was inserted into the DOM.

更新:事实证明我的问题完全是由于其他原因(意外地包括两次Ember.js)。上面的代码实际上似乎工作正常。

1 个答案:

答案 0 :(得分:0)

使用Ember.ContainerView,并使用自己的模板将每个内部视图作为自己的视图类。然后,您可以在包含视图上设置childViews数组,以包含要显示的任何视图的实例。