Dilettante_Pro,
доделал мальца, чтобы циферки в полях отображались
Агрегат
<select name='sel1'>
<option value='1480'>Вал тип 1</option>
<option value='2556'>Вал тип 2</option>
</select><br>
Цена: <span id="sel1">0</span> руб <br>
Центральная смазка
<select name='sel2'>
<option value='0'>Нет</option>
<option value='23'>Да</option>
</select><br>
Цена: <span id="sel2">0</span> руб <br>
Двойной подшипник
<select name='sel3'>
<option value='0'>Нет</option>
<option value='22'>Да</option>
</select><br>
Цена: <span id="sel3">0</span> руб <br>
Общая стоимость выбранных позиций: <span id="sum">0</span> руб<br><br>
<table>
<tr>
<td>Доставка и запуск под ключ</td>
<td>
<select name='dost1'>
<option value='0'>Нет</option> <!-- в случае выбора этого пункта прибавить 0 к итогу -->
<option value='3000'>Да</option> <!-- в случае выбора этого пункта, заблокировать dost2 прибавить 3000 к итогу -->
</select></td>
<td><span id="dost1">0</span>руб</td></tr>
<tr>
<td>Доставка до склада</td>
<td>
<select name='dost2'>
<option value='-1'>Нет</option>
<option value='0'>Омск</option> <!-- value = 0% от sel1 -->
<option value='1.5'>Новосибирск</option> <!-- в случае выбора этого пункта, заблокировать dost1 и
прибавить 1.5% от sel1 к итогу -->
<option value='3'>Москва</option> <!-- в случае выбора этого пункта, заблокировать dost1 и
прибавить 3% от sel1 к итогу -->
</select></td>
<td><span id="dost2">0</span>руб</td>
</tr>
</table>
<b>Итого с доставкой: <span id="result">0</span> руб<b>
<script src="https://ajax.googleapis.com/ajax/libs/jquery/1.12.4/jquery.min.js"></script>
<script type="text/javascript">
var sum = 0, dost = 0;
$(document).ready(function(){ $("select[name^='sel']").trigger('change'); }); //Установить цену при загрузке страницы
$("select[name^='sel']").change(function() {
$("#"+ this.name).html(splitRange(+this.value));
var s = $('select[name^="sel"] option:selected').map(function() {
return this.value
}).get()
sum = s.reduce((pv, cv) => {
return pv + (parseFloat(cv) || 0);
}, 0);
$("#sum").text(splitRange(sum)); //Разделить разряды
$('#result').text(splitRange(sum + dost));
});
var dost1 = $("select[name='dost1']"), dost2 = $("select[name='dost2']");
dost1.change(function() {
if(this.value == '0') {
dost1.hide();
dost2.show();
}
else {
dost2.hide();
};
dost = +this.value;
$("#"+ this.name).html(splitRange(dost));
$('#result').text(splitRange(sum + dost));
});
dost2.change(function() {
if(this.value == '-1') {
dost2.hide();
dost1.show();
dost = 0;
}
else {
dost1.hide();
dost =Math.round(sum * (+this.value) / 100);
};
$("#"+ this.name).html(splitRange(+dost));
$('#result').text(splitRange(sum + dost));
});
function splitRange(val) {
var str = val.toString();
return str.replace(/(\d)(?=(\d\d\d)+([^\d]|$))/g, '$1 ');
}
function joinRange(val) {
return val.replace(/\s/gi,'');
};
</script>