JSRUN 用代码说话

包裹内容

编辑教程

包裹内容

准备工作:

ember g route wrapping-content-in-component-route
ember g component wrapping-content-in-component

有些情况下,你需要定义一个包裹其他模板提供的数据的组件。比如下面的例子:


<h1>{{title}}</h1>
<div class='body'>{{body}}</div>

上述代码定义了一个普通的组件。

{{wrapping-content-in-component title=model.title body=model.body}}

调用组件,传入两个指定名称的参数,更多有关组件参数传递问题请看Ember.js 入门指南之二十九属性传递。

下面在route中增加一些测试数据。

//  app/routes/wrapping-content-in-component-route.js

import Ember from 'ember';

export default Ember.Route.extend({
    model: function() {
        return { id: 1, title: 'test title', body: 'this is body ...', author: 'ubuntuvim' };
    }
});

在上述例子中组件正常显示出model回调中初始化的数据。但是如果你定义的组件需要包含自定义的HTML内容呢??

除了上述这种简单的数据传递之外,Ember还支持使用block form(块方式),换句话说你可以直接传递一个模板到组件中,并在组件中使用{{yield}}助手显示传入进来的模板。

为了能使用块方式传递模板到组件中,在调用组件的时候必须使用#开始的方式(两种调用方式:{{component-name}}或者{{#component-name}}……{{/component-name}}),注意一定要有关闭标签!

稍加改造前面的例子,这时候不只是传递一个简单的数据,而是传入一个包含HTML标签的简单模板。


<h1>{{title}}</h1>

<div class='body'>{{yield}}</div>

注意此时div标签内使用的是{{yield}}助手,而不是直接使用{{body}}。

下面是调用组件的模板。

{{!wrapping-content-in-component title=model.title body=model.body}}

{{#wrapping-content-in-component title=model.title}}
    {{model.body}}
    <small>by {{model.author}}</small>
{{/wrapping-content-in-component}}
JSRUN闪电教程系统是国内最先开创的教程维护系统, 所有工程师都可以参与共同维护的闪电教程,让知识的积累变得统一完整、自成体系。 大家可以一起参与进共编,让零散的知识点帮助更多的人。
X
支付宝
9.99
无法付款,请点击这里
金额: 0
备注:
转账时请填写正确的金额和备注信息,到账由人工处理,可能需要较长时间
如有疑问请联系QQ:565830900
正在生成二维码, 此过程可能需要15秒钟