5. Ember.js学习- 模板

改变URL可以使得模板在屏幕上展示的内容发生变化

在ember.js中,模板从controller中获取信息

两个内建的controller(Ember.ObjectController和Ember.ArrayController)使得controller展示模板属性变得容易。

为了告诉controller去展示哪一个model,需要在route中得setupController方法中设置model属性

屏幕快照 2015-04-18 下午9.37.41.png

setupController方法将route handler关联的controller作为其第一个参数,在次情况下,PostRoute的setupController方法接收到的是应用程序的实例App.PostController。

指定一个controller而不是使用Ember默认生成的,可以设置route的controllerName属性。

setupController方法的第二个参数是route操作的model。

默认的setupController方法将route handler的model设置为关联controller的model属性。

如果你要配置一个controller而不是route handler关联的controller,使用controllerFor方法:

屏幕快照 2015-04-18 下午9.54.14.png

RENDERING A TEMPLATE

路由的一个重要的工作就是将正确的模板渲染到屏幕上,默认情况下,route handler会将模板渲染到最近的父模板中。

屏幕快照 2015-04-18 下午10.05.28.png

如果你想要渲染一个并非route handler关联的模板,那么需要实现renderTemplate方法:

屏幕快照 2015-04-18 下午10.08.03.png

如果你想要使用一个不同的controller,而不是route handler默认的controller,将controller的名字传递给controller选项。

屏幕快照 2015-04-18 下午10.10.32.png

Ember允许你给outlet取名字,下面的代码允许你为两个outlet指定不同的名字:

屏幕快照 2015-04-18 下午10.12.18.png

因此,如果你要将posts渲染到sidebar outlet中,应该使用下面的代码:

屏幕快照 2015-04-18 下午10.13.34.png

上面提到的所有选项可以放在一起使用:

屏幕快照 2015-04-18 下午10.14.23.png

如果你要将两个不同的模板渲染到两个不同的模板中,代码应该是下面这样:

屏幕快照 2015-04-18 下午10.16.14.png
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • 命名约定 我们在使用Ember.js创建routes,controllers和templates时,要遵循Embe...
    江枫阅读 4,210评论 0 1
  • THE APPLICATION TEMPLATE application模板是程序的默认模板,会在应用启东市被渲染...
    江枫阅读 4,410评论 0 1
  • 22年12月更新:个人网站关停,如果仍旧对旧教程有兴趣参考 Github 的markdown内容[https://...
    tangyefei阅读 35,310评论 22 257
  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 136,095评论 19 139
  • AngularJS是什么?AngularJs(后面就简称ng了)是一个用于设计动态web应用的结构框架。首先,它是...
    200813阅读 5,581评论 0 3

友情链接更多精彩内容