将属性传递给组件

组件不会在模板范围内直接访问属性。因此,只需在组件减速时声明该属性(例如:{{component-name title=title}})。外部模板范围内的 title 属性在组件模板内可用。

语法

{{post-action title=title}}

在上面的代码中,"post-action"组件具有"title"属性,并使用与属性名称相同的名称("title")进行初始化。

示例

下面给出的示例描述了如何将属性传递给组件。创建一个名为 post-action 的路由,并打开 router.js 文件以定义 URL 映射 −

import Ember from 'ember';
//以变量 Ember 的形式访问 Ember.js 库
import config from './config/environment';
//它以变量 config 的形式提供对应用程序配置数据的访问

//const 声明只读变量
const Router = Ember.Router.extend ({
   location: config.locationType,
   rootURL: config.rootURL
});

Router.map(function() {
   this.route('post-action');
});

//它指定可供应用程序其他部分使用的路由器变量
export default Router;  

现在使用以下代码打开组件模板文件 post-action.hbs

<p>Enter your data: {{input type = "text" value = title}}</p>
<p>The details of the object passed are : {{title}}</p>
{{yield}}

打开 index.hbs 文件并添加以下代码 −

{{post-action title=title}}
{{outlet}}

使用以下代码打开在 app/routes/ 下创建的文件 post-action.js

import Ember from 'ember';

export default Ember.Route.extend ({
   model: function() {
      //assigning the default value for 'title' property
      return {
         title: ""
      };
   }
});

输出

运行 ember 服务器;您将收到以下输出 −

Ember.js 组件传递属性

emberjs_component.html