gpt4 book ai didi

javascript - meteor 助手中未拾取 session 变量

转载 作者:行者123 更新时间:2023-12-03 06:32:19 26 4
gpt4 key购买 nike

我有一个选择下拉菜单。更改事件触发要设置的 session 变量。我想使用此 session 变量来填充表,但是,模板未读取 session 变量。我哪里出错了?

<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>

此时控制台日志显示未定义。从下拉列表中选择某些内容后,该值将设置为 session 变量。

下表是上述模板的延续。但是,控制台日志似乎没有打印与 schemaLabel helper

有关的任何内容
<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>

事件:

首先, session 变量值是未定义的。当我不断更改下拉列表中选定的元素时, session 变量值不断变化,这很好。

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");
}
});

帮助者:

当我不断更改下拉菜单时,下面的控制台日志也不断变化,这又是一个好兆头,因为我的 session 变量可以在帮助程序中访问。

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};});

}
});
<小时/>

更新:

经过进一步修改,我注意到 session 变量在 schemaLabels 辅助函数中仅在一开始就被调用一次。它被设置为未定义。之后,就再也不会调用它了。因此,无论我选择哪个下拉列表,该表都不会填充任何内容。

最佳答案

我不明白为什么您认为应该调用 schemaLabels 帮助程序。您正在使用两个不同的 session 变量(selectedSchemaschemaName),因此这些助手是分开的。

因此,如果您希望每次更改 selectedSchema(Session)、schemaLabels 调用的帮助程序时,您必须像这样修改 schemaLabels:

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};});

}

关于javascript - meteor 助手中未拾取 session 变量,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/38393354/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com