だから、私はこれを行うための動的な方法を考えて取得するためにカルマンに感謝、次のようにパラメータとしてとviewIndex
より多くのjavascriptを使用して!私の解決策は基本的にはヘルパー関数を呼び出すことによってヘルパーと "this"キーワードを使用して、{{#item}}内の現在のアイテムのすべての値を "this"に渡していたので、本質的にこれが可能になりました:
variationImage() {
return this.colors[Template.instance().variation.get()].imageLink[0];
},
variationLink() {
return this.colors[Template.instance().variation.get()].referralLink;
},
variationPrice() {
return this.colors[Template.instance().variation.get()].price;
}
そして、私は価格を必要なところ、その時点でこれらの値を取得することは{{variationPriceを}}使用するのと同じくらい簡単だった、など
{{#with item}}
<h3 class='display-price'>$ {{variationPrice}}</h3>
{{/with}}
そして、ちょうどバリエーションは各項目を働いていた方法についての詳細を追加します(私たちはそれらを掻き取っているので)非常にランダムな数のバリエーションを持っているので、これらのラインに沿って何かをして、そこにいくつのものがあるかを表現し、どのバリエーションを設定する必要がありますEを見て:
(ここで、色である項目の異なった色の変化を含む配列)
{{#each colors}}
<option value='{{@index}}'>Variation {{variationIndex @index}}</option>
{{/each}}
(ヘルパー関数)
variationIndex(index) {
return index+1;
}
(変動値を設定するイベント関数)
'change .color-variation-select': function(event, template) {
template.variation.set($(event.target).val());
},
括弧なしで試しましたか?私は.. '$ {{colors。[viewIndex] .price}}'です。私はMeteorやSpacebarsのテンプレートを使用していないので、私はただ推測しています。 – Will
あなたは実際に何をしようとしているかについてもっと説明できますか?これは奇妙なパターンです。要素にアクセスするためには、インデックスを表示ループ内に置く必要はほとんどありません。 –
はい、私はかっこなしで、かっこと括弧なしで試しました。ドロップダウンメニューをクリックして変更できるようにしようとしている項目の本質的なバリエーションがあります。 – Rheisen