我注意到每次 Meteor/Iron Router 更改路由时,整个页面都会刷新。
为什么会发生这种情况,我该如何预防?
对于每条新路线,我设置路线的方式都是这样的......
Router.route('/route/:_some_param', {
name: 'something',
onBeforeAction: function(){ // Something },
waitOn: function(){ // Some subscription },
action: function(){ // Something },
})
我以这种方式设置了几条路线。每当我从一个页面移动到另一个页面时,Meteor 都会重新加载整个页面。但是,当我停留在一条路线上并仅更改参数时,Meteor 只会重新加载必要的内容,而这正是我一直想要的。
最佳答案
我相信您所观察到的是 Iron Router 如何工作的基础。您使用 {{> yield }}
创建主模板模板占位符,Iron Router 将其替换为给定路由指定的模板。如果您选择不同的路线,{{> yield }}
现在将指向新模板,因此页面的该部分将被重新渲染。您可以通过最小化 {{> yeild }}
的范围来最小化被换出的页面数量。在您的主模板中。
例如,在我的模板中,我有一个像这样的页眉和页脚:
<html>
{{> header }}
{{> yield }}
{{> footer }}
</html>
当我导航路线时,页眉和页脚根本不会更新,只是它们之间的“胆量”。
关于meteor - 更改路线时防止 Meteor/Iron 路由器重新加载,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27689316/