Ric*_*ick 17 javascript meteor
在Meteor中我使用Backbone来为我的应用程序中的不同页面提供路由.我目前有个人资料和管理页面.当我进入个人资料页面时,它就会显示出来,但是当我去管理时,Meteor会回到主页面.
作为旁注,如果有人对Meteor中的页面有更好的模式或最佳实践,请随意分享,因为这非常麻烦.
我使用以下模板来决定要显示的页面:
<template name="root">
{{> navbar}}
{{#if pageIs "profile"}}
{{> profile}}
{{else}}{{#if pageIs "administration"}}
{{> administration}}
{{else}}
{{> main_page}}
{{/if}}
{{/if}}
</template>
Run Code Online (Sandbox Code Playgroud)
pageIs方法如下:
Template.root.pageIs = function(page){
console.log(Session.get('page'));
return page === Session.get('page');
}
Run Code Online (Sandbox Code Playgroud)
以及我的Backbone路由器中的以下代码:
var ProtonRouter = Backbone.Router.extend({
routes: {
"profile": "profile",
"admin": "administration",
"administration":"administration"
},
profile: function () {
Session.set('page','profile');
},
administration: function (){
Session.set('page', 'administraion');
},
mainPage: function(){
Session.set('page',null);
}
});
Run Code Online (Sandbox Code Playgroud)
pageIs方法中的日志语句将多次记录未定义,然后记录正确的页面,即使在管理时也是如此,但Meteor似乎无法重新加载所选页面,模板仍然会触及最后一个else语句.
And*_*Mao 25
更新:Iron路由器已被弃用,转而使用Flow Router.有强烈迹象表明Flow Router将在未来作为核心流星的一部分得到支持.
OUTDATED:以前常用的路由器是Iron Router:
在其发布时,Iron Router结合了两个最广泛使用的流星路由器(流星路由器和迷你页面)的作者的努力,并且在流路由器之前是Meteor的事实上的官方路由器.
很多人使用这个路线系统:
https://github.com/tmeasday/meteor-router
这对Meteor来说非常容易使用和制作.
归档时间: |
|
查看次数: |
9833 次 |
最近记录: |