• 设为首页
  • 点击收藏
  • 手机版
    手机扫一扫访问
    迪恩网络手机版
  • 关注官方公众号
    微信扫一扫关注
    公众号

Ember 包裹内容

原作者: [db:作者] 来自: [db:来源] 收藏 邀请

准备工作:

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}}

页面加载之后效果如下:

查看页面HTML源代码,可以看到在

这个标签内的内容确实是调用组件wrapping-content-in-component传入进来的简单HTML模板。你可以把{{#wrapping-content-in-component}}……{{/wrapping-content-in-component}}中间的内容当做是一个参数理解。

到此组件包裹内容的知识点介绍完毕,内容很少也比较简单!如果有疑问请给我留言或者直接看官方教程


博文完整代码放在Github(博文经过多次修改,博文上的代码与github代码可能有出入,不过影响不大!),如果你觉得博文对你有点用,请在github项目上给我点个star吧。您的肯定对我来说是最大的动力!!


鲜花

握手

雷人

路过

鸡蛋
该文章已有0人参与评论

请发表评论

全部评论

专题导读
上一篇:
Ember 自定义包裹组件的HTML标签发布时间:2022-01-29
下一篇:
Ember 属性传递发布时间:2022-01-29
热门推荐
热门话题
阅读排行榜

扫描微信二维码

查看手机版网站

随时了解更新最新资讯

139-2527-9053

在线客服(服务时间 9:00~18:00)

在线QQ客服
地址:深圳市南山区西丽大学城创智工业园
电邮:jeky_zhao#qq.com
移动电话:139-2527-9053

Powered by 互联科技 X3.4© 2001-2213 极客世界.|Sitemap