0

现在,我正在我的 ember 应用程序中构建一个特定的屏幕,其中包含未知数量的嵌套组件。因此,我试图不根据正在显示的组件更改 url,还有一些我想在每个子屏幕上显示的基本信息。

目前,当真正的动作逻辑仅在路线上定义时,我似乎必须重新定义并在所有这些动作名称中传递所有这些动作名称。有没有办法在控制器或一个“父”组件中干燥这些动作引用。

这是一个示例 ember-twiddle,我将这些组件渲染到一个插座http://ember-twiddle.com/31a69c62ceddcb69b02b

这是路线的示例

import Ember from 'ember';

export default Ember.Route.extend({
  _fixtureModels: [
    { person: {name: 'bill'}, sideModel: null},
    { person: {name: 'bill'}, sideModel: { postName: 'test post' }},
    { person: {name: 'bill'}, sideModel: { commentName: 'test comment'}}
    ],

  _renderSideModel: function (template, sideModel) {
    this.render();

    this.render(template, {
      outlet: 'side-model',
      into: 'index',
      model: sideModel
    });
  },

  renderTemplate: function () {
    this.render();

   this.render('someComponentWrapper', {
     outlet: 'side-model',
     into: 'index'
   });
  },

  model: function () {
     return this._fixtureModels[0];
  },

  actions: {
    renderTopLevel: function () {
      return this.renderTemplate();
    },
    renderPost: function () {
      return this._renderSideModel('post', this._fixtureModels[1]);
    },
    renderComment: function () {
      return this._renderSideModel('comment', this._fixtureModels[2]);
    }
  }
});

我知道 URL 应该是 Ember 中的王者,这是非常有罪的,但是很难重建一个潜在的嵌套视图。

4

1 回答 1

0

所以你必须重新定义所有这些动作名称的原因是因为组件被设计为隔离的,即在任何地方重用。但是,您可以使用两个快捷方式:

  1. 应用默认操作名称:

您可以在组件中使用默认操作名称,以避免在每个模板中都指定它。

// components/some-component.js

export default Ember.Component.extend({
    renderPost: "renderPost",
    renderComment: "renderComment"
});

// some template where you are using this component

{{some-component-wrapper renderPost="myRenderPost"}}
{{!overrides renderPost, but "inherits" an action named renderComment}}
  1. 使用关闭操作(如果您使用的是 Ember 1.13 或更高版本):

http://emberjs.com/blog/2015/06/12/ember-1-13-0-released.html#toc_closure-actions

这是一项新功能,可让您向下传递函数而不是操作的名称。

于 2015-07-28T11:01:13.620 回答