5. Ember.js学习- 模板

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

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

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

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

5. Ember.js学习- 模板_第1张图片
屏幕快照 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方法:

5. Ember.js学习- 模板_第2张图片
屏幕快照 2015-04-18 下午10.08.03.png

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

5. Ember.js学习- 模板_第3张图片
屏幕快照 2015-04-18 下午10.10.32.png

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

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

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

5. Ember.js学习- 模板_第4张图片
屏幕快照 2015-04-18 下午10.13.34.png

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

5. Ember.js学习- 模板_第5张图片
屏幕快照 2015-04-18 下午10.14.23.png

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

5. Ember.js学习- 模板_第6张图片
屏幕快照 2015-04-18 下午10.16.14.png

你可能感兴趣的:(5. Ember.js学习- 模板)