Вы можете проиндексировать цены в двумерной карте при загрузке страницы (с рабочим fiddle).
1) Я поставил выбрать значения в подстановок-таблиц в случае, если вы должны предварительно загрузить их:
var tables = {
Colour: ["Blue", "Red"],
Size: ["Small", 'Medium, "Large"]
};
2) Вот ваша таблица цен в виде массива:
var array = [
{Colour: "Blue", Size: "Small", Price: 45},
{Colour: "Blue", Size: "Medium", Price: 48},
{Colour: "Blue", Size: "Large", Price: 98},
{Colour: "Red", Size: "Small", Price: 65},
{Colour: "Red", Size: "Large", Price: 31}
];
3) Инициализация выбирает (населяющие значения и событие 'изменение'):
for (var key in tables)
if (tables.hasOwnProperty(key)) {
selects[key] = form[key];
selects[key].addEventListener("change", updateSpan);
var values = tables[key];
len = values.length;
for (i = 0; i < len; i++) {
var option = document.createElement('option');
option.appendChild(document.createTextNode(values[i]));
form[key].appendChild(option);
}
}
4) индексировать вашу ценовую таблицу:
len = array.length;
for (i = 0; i < len; i++) {
var record = array[i];
if (typeof map[record.Colour] === 'undefined')
map[record.Colour] = {};
map[record.Colour][record.Size] = record.Price;
}
5) Функция updateSpan (на изменение выбора):
function updateSpan() {
var Colour = selects.Colour.options[selects.Colour.selectedIndex].value;
var Size = selects.Size.options[selects.Size.selectedIndex].value;
if (typeof map[Colour] !== 'undefined' && typeof map[Colour][Size] !== 'undefined')
span.textContent = map[Colour][Size];
else
span.textContent = "Price not defined to Colour: " + Colour + " and Size: " + Size + ".";
}
6) Отладка (хит F12 в Chrome или Firefox, чтобы открыть консоль View).
Полный индексированной таблице:
console.log(map);
Только цена 'Blue' & 'Малый':
console.log(map['Blue']['Small']); // outputs: 45
Почему JQuery, а не просто JS? Просто спросить ... – Yoshi
простой js будет работать так же ... :) был длинный день – Paul
Почему вы хотите сделать это с помощью jQuery? Более простой подход заключается в использовании многомерного массива javascript. –