如何在Meteor的同一个集合字段中添加来自相同表单的两个输入?

时间:2015-10-16 10:56:16

标签: javascript html mongodb meteor meteor-helper

我正在为我的第一个应用程序工作教程meteor。所以我想扩展一点,并有两个文本框,一个用于评论,一个用于评级。 问题是我无法正确获取两种形式的值(实际上根本无法得到评级值),以便将它们保存在我的数据库中,而且输入 - 提交功能停止工作。

我的.js身体事件代码是:

Template.body.events({
    "submit .new-task": function(event) {
        // Prevent default browser form submit
        event.preventDefault();

        // Get value from form element
        var text = event.target.text.value;
        var rating = event.target.rating.value;

        // Insert a task into the collection
        Meteor.call("addTask", text, rating);

        // Clear form
        event.target.text.value = "";

    }
});

添加任务:

AddTask: function(text, rating) {
    //.....
    Tasks.insert({
        text: text,
        createdAt: new Date(),
        owner: Meteor.userId(),
        username: Meteor.user().username,
        rating: rating
    });
}

我的HTML:

<form class="new-task">
    <h2>What is happening?</h2>
    <input type="text" name="text" placeholder="Share your experience!" />
    <h2>Rating:</h2>
    <input type="text" name="rating" placeholder="insert your rating!" />
</form>
<template name="task">
    <li class="{{#if checked}}checked{{/if}}">
        {{#if isOwner}}
        <button class="delete">&times;</button>
        {{/if}}
        <span class="text"><strong>{{username}}</strong> - {{text}}- {{rating}}</span>
    </li>
</template>

1 个答案:

答案 0 :(得分:1)

您的Meteor方法addTask未定义。请改为调用Meteor.call("AddTask", text, rating);,或将您的方法重命名为addTask

例如:

if (Meteor.isClient) {
    Template.hello.events({
        'click button': function () {
            Meteor.call("addTask", "1", 2, function(error){
                if (error) alert(error.reason);
            });
        }
    });
}

if (Meteor.isServer) {
    Meteor.methods({
        addTask: function (text, rating) {
            check(text, String);
            check(rating, Number);
            console.log(text);
            console.log(rating);
        }
    });
}