我有一个模板:
<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'});
};
如果#search文本字段为空,我想显示所有书签,如果不是,则显示我的书签。
我看到Template.bookmarks.bookmarks只调用一次 - 当浏览器中加载页面时。每当用户按下#search文本输入中的按钮时,如何调用此方法:
Template.search.events({
'keyup #search' : function(e,t) {
// ....
}
提前致谢。
答案 0 :(得分:2)
使用Session
var s = Session.get("query");
和
Template.search.events({
'keyup #search' : function(e,t) {
Session.set("query",t.find('#search').value);
}
模板bookmarks
帮助器本身不知道何时刷新数据。使用Session
告诉它query
变量/哈希是被动的。