我正在使用 Meteor、Handlebars 和 Backbone 创建一个多页应用程序。我有一个使用主干设置的路由器,它设置了一个会话变量,currentPage
. 如何根据 的值呈现不同的模板currentPage
?
有人告诉我,我可以创建一个可以执行此操作的模板辅助函数,但我不确定如何处理。
我正在使用 Meteor、Handlebars 和 Backbone 创建一个多页应用程序。我有一个使用主干设置的路由器,它设置了一个会话变量,currentPage
. 如何根据 的值呈现不同的模板currentPage
?
有人告诉我,我可以创建一个可以执行此操作的模板辅助函数,但我不确定如何处理。
如果 currentPage 是全局的并且页面存储为字符串,那么我希望这可以工作:
Handlebars.registerHelper('currentPageIs',function(page){
return currentPage == page;
});
// and in the html:
{{#if currentPageIs '/posts'}}
{{> posts}}
{{else}}
{{> homepage}}
{{/if}}
一个非常简单的解决方案在这里:https ://gist.github.com/3221138
但我强烈建议安装meteor-router。这将要求您首先安装陨石。
另外,要知道路线图上有官方路由解决方案。
最好的选择是使用 Iron-Router,但你不希望这是一个更改模板的好模式:
//HTML
<body>
{{>mainTemplate}}
</body>
//JS Client Initially
var current = Template.initialTemplate;
var currentDep = new Deps.Dependency;
Template.mainTemplate = function()
{
currentDep.depend();
return current;
};
function setTemplate( newTemplate )
{
current = newTemplate;
currentDep.changed();
};
//Later
setTemplate( Template.someOtherTemplate );
我不知道如何检查路线,但如果可以,那么您可以使用建议的setTemplate
功能有条件地更改模板。