我有一个模板:
<div id="search">
{{> search}}
</div>
<div id="bookmarks-container">
{{> bookmarks}}
</div>
<template name="bookmarks">
{{#each bookmarks}}
<div class="bookmark">
{{URL}}
</div>
{{/each}}
</template>
<template name="search">
<input type="text" id="search" value="" />
</template>
我有一个获取书签的代码:
bookmarks = new Meteor.Collection("Bookmarks");
if (Meteor.isClient) {
Template.bookmarks.bookmarks = function() {
var s = $('#search').text();
alert(s);
if (s === '')
return bookmarks.find({});
else
return bookmarks.find({tags : 'some_tag'});
};
如果#搜索文本字段为空,我想显示所有书签,如果不是,我想过滤我的书签。
正如我所看到的,Template.bookmarks.bookmarks只调用一次——在浏览器中加载页面时。当用户每次按下#搜索文本输入中的按钮时,我如何调用此方法:
Template.search.events({
'keyup #search' : function(e,t) {
// ....
}
提前谢谢。
用Session
中继数据
var s = Session.get("query");
和
Template.search.events({
'keyup #search' : function(e,t) {
Session.set("query",t.find('#search').value);
}
模板bookmarks
助手本身不知道何时刷新数据。使用Session
告诉它query
变量/散列是反应性的。