Ember DRY 具有相同操作的嵌套组件

Ember DRY nested components with same actions

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

目前,当真正的动作逻辑只在路由上定义时,我似乎必须重新定义并在所有地方传递所有这些动作名称。有没有办法 可能在控制器或一个 "parent" 组件中干燥这些动作引用。

这是一个示例 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 中的国王,这是非常有罪的,但重建潜在的嵌套视图将非常困难。

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

  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

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