私は非常に単純であるべき何かへの答えを求めてSOの質問をトロールしてきましたが、私の人生ではそれを理解することはできません.
基本的に、2 つの選択コントロールを持つ meteor-autoform があります。
<template name="processFormTemplate">
{{#autoForm id="processForm" collection="Processes" type=formAction doc=doc validation="blur"}}
<div class="col-md-12">
{{> afQuickField name="elementId" options=elements}}
{{> afQuickField name="categoryId" options=categories}}
{{> afQuickField name="title"}}
{{> afQuickField name="desc" rows=4}}
</div>
{{>formButtons}}
{{/autoForm}}
</template>
これらには、オプションを設定するためのヘルパーがあります。
Template.processFormTemplate.helpers({
elements: function() {
return getFormElements();
},
categories: function(elementId) {
return getFormCategories(this.doc.elementId);
}
});
lib/methods.js
getFormElements = function() {
var options = [];
Elements.find({}, {sort: {ref:1}}).forEach(function (element) {
options.push({
label: element.title, value: element._id
});
});
return options;
};
getFormCategories = function(elementId) {
var options = [];
var filter = {};
if (!isBlank(elementId)) {
filter.elementId = elementId;
}
Categories.find(filter, {sort: {ref:1}}).forEach(function (d) {
options.push({
label: d.title, value: d._id
});
});
return options;
};
ヘルパーが反応的ではないため、これが機能していないことはわかっていますが、この動作を変更する方法はわかりません。また、「変更」イベントにフックしようとしましたが、何らかの理由でこれが発生することはありません:
Template.processFormTemplate.events({
'change #elementId': function(e) {
console.log($('[name="elementId"]').val() + ' is now selected');
}
});
必要な動作は、最初のリストで新しい elementId が選択されたときに、選択された elementId に基づいて 2 番目のオプションのリストが更新されることです。
どんな助けでも大歓迎です。
ありがとう、デビッド