我有一个选择下拉菜单。更改事件会触发要设置的会话变量。我想使用此会话变量来填充表,但是,模板不会读取会话变量。我哪里错了?
<template name ='defaultTemplate'>
<label for="Schema" class="control-label">Select the Schema</label>
<select required="true" class="form-control" id="schemaNameId">
<!-- <option default>Select Schema </option> -->
{{ #each schemaNames}}
<option value="{{schemaName}}">{{schemaName}}</option>
{{/each}}
</select>
此时的控制台日志表示未定义。从下拉列表中选择一些内容后,该值将被设置为会话变量。
下表是对上述模板的继续。但是,控制台日志似乎不打印任何与schemaLabel
帮助程序
<table class="table table-bordered table-condensed">
<thead>
<tr>
<td style="width: 85px">Label</td>
<td>Current Value</td>
<td style="width: 250px">New Value</td>
</tr>
</thead>
<tbody>
{{#each schemaLabels}}
<tr>
<td>{{this.label}}</td>
<td>{{this.value}}</td>
</tr>
{{/each}}
</tbody>
</table>
</template>
事件:
首先,会话变量值未定义。当我不断更改下拉列表中的选定元素时,会话变量值会不断变化,这很好。
Template.defaultTemplate.events({
"change #schemaNameId": function(event, template){
var selectValue = template.$("#schemaNameId").val();
// console.log(selectValue +" is selected from dropdown - message logged in events");
Session.set("selectedSchema",selectValue);
console.log(Session.get("selectedSchema")+ " is session variable set - message logged in events");
}
});
助手:
当我不断更改下拉列表时,下面的控制台日志也会不断变化,这也是一个好兆头,因为我的会话变量可以在帮助程序中访问。
Template.defaultTemplate.schemaNames({
schemaNames: function () {
console.log(Session.get("selectedSchema")+ " is session variable - message logged in defaultTemplate:schemaNames");
return Defaults.find({},{schemaName:1}).map(function(c) {return {schemaName : c.schemaName};
});
},
但是,对于以下功能,控制台日志根本不打印任何内容!这意味着控制永远不会达到这一点,即使所有这些都在同一个助手类中。
schemaLabels: function() {
var selectedSchema = Session.get("schemaName");
console.log(Session.get("schemaName") +"is the selectedSchema - message logged in defaultTemplate:schemaLabels");
return Defaults.find({schemaName:selectedSchema},{_id:0,schemaName:0}).map(function(c) {return {label : c.label, value: c.value};});
}
});
进一步修改后,我注意到会话变量在一开始只从schemaLabels辅助函数中调用一次。它设置为undefined。在那之后,永远不会打电话给这个。因此,无论我选择什么下拉列表,表格都不会填充任何内容。
答案 0 :(得分:1)
我不明白为什么你认为schemaLabels
助手应该被召唤。
您正在使用两个不同的会话变量(selectedSchema
和schemaName
),因此这些帮助程序是分开的。
因此,如果您希望每次更改selectedSchema
(会话),调用schemaLabels
帮助程序时,您必须修改schemaLabel,如下所示:
schemaLabels: function() {
var foo = Session.get("selectedSchema");
var selectedSchema = Session.get("schemaName");
console.log(Session.get("schemaName") +"is the selectedSchema - message logged in defaultTemplate:schemaLabels");
return Defaults.find({schemaName:selectedSchema},{_id:0,schemaName:0}).map(function(c) {return {label : c.label, value: c.value};});
}