3

当我在我的应用程序中导航时,我经常会收到这个错误,这会进一步破坏我应用程序中的所有导航,我必须重新加载整个页面:

Uncaught You can't call rerender on a view being destroyed

我和 Ember IRC 频道上的几个男孩找出了导致问题的原因。

我使用的是来自https://github.com/emberjs/group-helper的组助手。整个应用程序都设置为使用它,如果我删除它,很多东西都会中断,因为很多变形标签开始再次被创建。

知道如何修改帮助程序以使错误消失吗?

var get = Ember.get, set = Ember.set, EmberHandlebars = Ember.Handlebars;

EmberHandlebars.registerHelper('group', function(options) {
    var data = options.data,
        fn   = options.fn,
        view = data.view,
        childView;

    childView = view.createChildView(Ember._MetamorphView, {
        context: get(view, 'context'),
        template: function(context, options) {
            options.data.insideGroup = true;
            return fn(context, options);
        }
    });

    view.appendChild(childView);
});

更新:以下内容已过时,仅存在于原始帖子中

在我的应用程序中,我有这三个子类,我所有的视图、数组控制器和路由都基于它们。

看法:

PageView = Ember.View.extend({
    title: '',
    identifier: '',
    classNames: ['page'],
    willDestroyElement: function () {
        var elm_classes = this.$().attr('class') + ' out',
            elm_height = this.$().height(),
            temporary_container = $('<div class="'+elm_classes+'">');

        this.$().children().appendTo(temporary_container);

        temporary_container.insertAfter(this.$());

        window.setTimeout(function() {
            temporary_container.remove();
        }, animationKillDuration);
    },
    didInsertElement: function() {
        $(document).trigger('royalbeer-page-rendered');
    }
});

阵列控制器

RoyalArrayController = Ember.ArrayController.extend({
    goto: function(route, slug) {
        if (!slug)
            this.transitionToRoute(route);
        else
            this.transitionToRoute(route, slug);
    }
});

路线:

RoyalRoute = Ember.Route.extend({
    setupController: function(controller, model) {
        var modelName = this.routeName.substr(0, 1).toUpperCase() + this.routeName.substr(1),
            slug = model;
        if (model.hasOwnProperty('slug'))
            slug = model.slug;
        controller.set('model', App[modelName].find({'slug': slug}));
    },
    serialize: function(slug, params) {
        var name, object;
        object = {};
        name = params[0];
        object[name] = slug;
        return object;
    }
});

我使用数组控制器中的 goto 函数来绑定我的应用程序中的元素以进行导航{{action goto 'routename' slug}},并且我的路由上的序列化程序和 setupController 设置为能够处理该问题,这在错误发生之前可以正常工作。

我只能猜测是因为那些东西坏了。

关于发生了什么以及如何解决它的任何想法?

4

1 回答 1

2

我现在已经解决了这个问题,方法是一起删除组助手,并将我的所有 css 从使用 :first-child/:last-child 重写为 :first-of-type/:last-of-type。包括 Twitter 引导程序。有用。但我真的很想要一种方法来让 Ember 通常不会用变形标记来膨胀我的 DOM。

于 2013-07-03T08:43:15.943 回答