我的 Meteor 应用程序中有以下模板:
<template name="items">
<div class="mainframe">
<h3>Available items:</h3>
<div class="items-table-container">
<table class="table table-hover">
<tbody>
{{#each all_items}}
{{> item}}
{{/each}}
</tbody>
</table>
</div>
</div>
<div class="btn-group">
<button id="create" class="btn">Create new item</button>
</div>
</template>
模板函数很简单:
Template.items.all_items = function () {
return Items.find({}, {sort: {name: 1}}).fetch();
}
还有一个绑定到#create
按钮的事件,它将一个新项目插入到 Items 集合中,并且工作正常。
现在最重要的部分是 CSS:
.items-table-container {
height:340px;
overflow-y: scroll;
}
所以基本上我希望我的表格在固定大小的区域内有可滚动的内容。当我在一个浏览器中向下滚动项目表的内容,然后在另一个浏览器中添加一个新项目时,问题就开始了。第一个浏览器更新项目列表并将内容滚动回顶部位置。
问题是如何防止单个模板的自动更新?我认为在这种特殊情况下,我实际上需要像传统网页更新这样的东西:如果用户没有立即看到新添加的项目,而是在他重新加载页面之后看到,那也没关系。
另一个想法是做某种分页而不是可滚动的内容。我认为这会解决问题,但这会复杂得多,我想避免这种情况。
我认为理想情况下我希望能够告诉 Meteor 我希望 Meteor 更新模板不是在模型更改时而是通过请求来更新。