0

我是新手,所以请多多包涵。我正在尝试将一个项目视图添加到另一个项目视图,但嵌套视图项目上的渲染方法返回一个延迟对象。

这是代码:

(function (ns, _, $, Backbone) {

///////////////////////////////////////////////////////////////////////////////////////
// Signup state
///////////////////////////////////////////////////////////////////////////////////////

var SignUp = Backbone.Marionette.ItemView.extend({
    template : "#signup-tmpl",
    events : {
        'click .signup' : 'signup'
    },

    signup : function () {
        console.log('signup clicked');
        ns.app.layout.app.show(ns.views.register);
    },
    onRender : function() {
        console.log('On render', this.el);

        var user = ns.views.user.render();
        // user returns an a deferred object
        // so the code below does not work

        this.$el.find('#user').html(test.el);


    }
});

ns.views.signup = new SignUp();

}(H5, _, $, Backbone));

我做了一些阅读,我发现的修复是渲染视图,但抓住它的 el 属性(Backbone.Marionette 嵌套的 ItemView 要么不渲染或渲染“空白”视图/模板)后记。问题是“用户”返回一个延迟对象。

关于这里发生了什么的任何想法?

4

1 回答 1

1

您正在使用 Marionette.Async 吗?从渲染返回延迟对象对于促进异步处理模板、数据和渲染的方式是必要的,这些都是异步完成的。

使渲染不返回延迟的唯一方法是不使用 Marionette.Async - 和 FWIW,我推荐该解决方案。异步不应该直接在视图中完成,IMO。它应该由应用程序工作流处理,在视图实现之上的一个或多个抽象步骤。

于 2012-10-29T01:13:26.290 回答