每次我对应用程序有新想法时,我都会从 Meteor 开始。每次我最终使用别的东西。而且我认为归结为我不知道如何进行简单的数据库查询。
这是一个假设的例子。我想制作一个应用程序,用户在框中输入一些内容,按下一个按钮,然后显示他们输入的任何内容的图像。它使用一些图像搜索 api。
<template name="image">
<input type="text" class="description"></input>
<button class="showImage"></button>
<img src="{{img}}"></img>
</template>
到目前为止似乎很简单。根据我的理解,现在没有办法在不先将信息放入数据库的情况下将信息发送给客户。假设我们有一些函数 addToDB 接受查询并将图像信息输入数据库。
Template.image.events({
'click .showImage': function() {
addToDB($('.description').val());
}
});
伟大的!这还不算太糟糕。但是现在要将数据发送回客户端......
//server.js
Meteor.publish("image", function(query) {
Images.find({q: query});
}
可是等等。我们不能只在客户端加载时订阅,因为我们还不知道查询。所以也许事件处理程序需要
Template.image.events({
'click .showImage': function() {
addToDB($('.description').val());
Deps.autorun(function() {
Meteor.subscribe("images", $('.description').val());
});
}
});
好的,让我们将它输入到模板中......
Template.image.img = function() {
return Images.findOne().imgsrc;
}
不,这会导致错误,因为在第一次加载模板时,我们还没有订阅图像。所以我们可以像这样更新模板:
<template name="image">
<input type="text" class="description"></input>
<button class="showImage"></button>
{{#each info}}
<img src="{{info.img}}"></img>
{{/each}}
</template>
然后将模板填充函数更改为:
Template.image.info = function() {
return Images.find({}, {limit: 1});
}
瞧!
我花了比我愿意承认的时间更长的时间来完成今晚的所有事情。如果它只是普通的旧节点,我可以使用一些简单的 jQuery。
但是 Meteor 有上百万个令人惊叹的功能是我真正想利用的。所以我希望有人能给我指路。我在这个过程中犯了哪些错误,以及最终的结果是什么?在流星应用程序中完成这项工作的最好、最干净、最简单的方法是什么。
这太复杂了,在一个让许多其他事情变得如此简单的框架内。那么我怎样才能做一个简单的数据库查询呢?