Javascript Meteor使用数据库中的数据填充表单(如果有),如果没有,则显示表单
我正在学习如何使用MeteorJS。我正试图用数据库返回的信息预先填充表单,所有文本输入都没有问题,但我怎么能检查收音机??我从数据库中得到的是一个非常长的表单,至少有150个字段。所以我不得不处理很多,但我不知道如何处理。显然,我已经在检索正确的文档,所有其他字段都很好,来自收音机的值也很好,但是我如何使用handlebar或其他方式向它们添加checked属性呢Javascript Meteor使用数据库中的数据填充表单(如果有),如果没有,则显示表单,javascript,forms,meteor,radio-button,autofill,Javascript,Forms,Meteor,Radio Button,Autofill,我正在学习如何使用MeteorJS。我正试图用数据库返回的信息预先填充表单,所有文本输入都没有问题,但我怎么能检查收音机??我从数据库中得到的是一个非常长的表单,至少有150个字段。所以我不得不处理很多,但我不知道如何处理。显然,我已经在检索正确的文档,所有其他字段都很好,来自收音机的值也很好,但是我如何使用handlebar或其他方式向它们添加checked属性呢 Template.myTemp.helpers({ full : function () { var id =
Template.myTemp.helpers({
full : function () {
var id = Session.get('currentId');
if (id) {
return People.findOne({_id: id});
} else {
return true;
}
}
});
好的,这里返回true只是为了在没有定义会话的情况下显示没有预填充值的表单。接下来是我的模板的简短版本
<template name="myTemp">
{{#with full}}
<div class="input-field">
<label for="name" class="active">Name</label>
<input id="name" name="name" type="text" value= "{{name}}">
</div>
<p>
<input id="fem" name="sex" type="radio" value="FEM" class="with-gap">
<label for="fem">Female</label>
<input id="male" name="sex" type="radio" value="MALE" class="with-gap">
<label for="male">Male</label>
</p>
{{/with}}
</template>
{{#带满}
名称
女性
男性
{{/与}}
所以这里有一个技巧,当我使用这个表单来插入它时效果很好,但是当尝试预先填充它时,它是一个噩梦。如果我得到的返回值是数据库中以性别名称存储的表单中的值,我怎么能选中此单选按钮。我假设您的
人员
集合的文档与以下对象相似:
{ "_id" : "adCsEGoHFbpJbFjtP", "name" : "John Doe", "sex" : "male" }
{ "_id" : "TYLDYicCzpHSD5Sk5", "name" : "Jane Doe", "sex" : "female" }
如果是这种情况,您可以在myTemp
模板中定义一个帮助器,如果文档的属性type
与函数的参数匹配,该帮助器将返回字符串checked
:
if (Meteor.isClient) {
Template.myTemp.helpers({
full: function () {
var id = Session.get('currentId');
if (id) return People.findOne({_id: id});
else return true;
},
isChecked: function (type) {
return (this && this.sex === type) ? 'checked' : null;
}
});
}
People = new Mongo.Collection("people");
if (Meteor.isServer) {
Meteor.startup(function () {
People.insert({
"name": "John Doe",
"sex": "male"
});
People.insert({
"name": "Jane Doe",
"sex": "female"
});
});
}
{{#带满}
名称
女性
男性
{{/与}}
下面是一个例子。我在您提供代码时尝试了您的代码,效果非常好。但是你能帮我一点忙吗?我不明白函数(类型)是如何工作的。参数类型来自何处。我无法使它与我的代码一起工作,即使是通过复制您的代码的粘贴。因此,我认为如果我能理解你的代码,我也许能让事情顺利进行。参数
类型
可以通过Meteor模板助手传递,比如{{isChecked'female'}
或{{isChecked'male'}
。
<template name="myTemp">
{{#with full}}
<div class="input-field">
<label for="name" class="active">Name</label>
<input id="name" name="name" type="text" value="{{name}}">
</div>
<p>
<input id="fem" name="sex" type="radio" value="FEM" class="with-gap" {{isChecked 'female'}}>
<label for="fem">Female</label>
<input id="male" name="sex" type="radio" value="MALE" class="with-gap" {{isChecked 'male'}}>
<label for="male">Male</label>
</p>
{{/with}}
</template>