26.02.2017, 21:27
|
|
Профессор
|
|
Регистрация: 27.05.2010
Сообщений: 33,109
|
|
MixPetrov,
data-maximum="125" data-minimum="10"
<!DOCTYPE html>
<html>
<head>
<title>Untitled</title>
<meta charset="utf-8">
<style type="text/css">
</style>
<script src="https://ajax.googleapis.com/ajax/libs/jquery/1.12.4/jquery.min.js"></script>
<script>
$(function() {
function mathC() {
var nmb = +this.dataset.nmb;
var ns = +this.value.replace(/\D/g, "") || 0;
ns = Math.ceil(ns / nmb) * nmb;
this.value = ns
}
function is() {
var maximum = +this.dataset.maximum;
var minimum = +this.dataset.minimum;
var ns = +this.value.replace(/\D/g, "") || 0;
if (ns > maximum) ns = maximum;
if (ns < minimum) ns = minimum;
this.value = ns;
}
var timer;
$('.quantity_cart [type="text"]').on("input", function() {
window.clearTimeout(timer);
var self = this;
timer = window.setTimeout(function() {
mathC.bind(self)();
is.bind(self)()
},1200)
})
});
</script>
</script>
</head>
<body>
<div class="quantity_cart">
<input type="text" name="product_id" size="2" value="20" data-maximum="125" quantity="125" data-minimum="10" data-nmb="10" type="text">
</div>
</body>
</html>
Последний раз редактировалось рони, 26.02.2017 в 21:31.
|
|
26.02.2017, 21:43
|
Аспирант
|
|
Регистрация: 12.10.2016
Сообщений: 53
|
|
Спасибо, но в данном случае лучше когда на каждую функцию свой таймер. Эти функции находятся в файле *.php и выполняются в правильном порядке, но есть еще одна функция она написана в файле *.js и она выполняется самой первой, а надо чтобы выполнялась последней.
|
|
26.02.2017, 22:20
|
|
Профессор
|
|
Регистрация: 27.05.2010
Сообщений: 33,109
|
|
MixPetrov,
не осилил
|
|
26.02.2017, 22:55
|
Аспирант
|
|
Регистрация: 12.10.2016
Сообщений: 53
|
|
Работа скриптов должна выстраивается в следующем порядке -
mathC - округляет value;
is - задает верхнюю и нижнюю границы для value (max i min);
recalc - умножает value на стоимость.
В данное время скрипты выполняются в следующем порядке:
recalc;
mathC;
is.
Все скрипты выполняются при oninput
|
|
26.02.2017, 23:10
|
|
Профессор
|
|
Регистрация: 27.05.2010
Сообщений: 33,109
|
|
MixPetrov,
думайте сами у меня вариантов нет, но затруднять ввод клиентом данных плохая практика, возможен только запрет на не цифровые символы, выводить результат надо в другом месте, а не в том которое используют для ввода.
|
|
26.02.2017, 23:23
|
Аспирант
|
|
Регистрация: 12.10.2016
Сообщений: 53
|
|
Результат функции recalc выводится в другом месте.
Выведен HTML в firebug
<div class="quantity_cart">
<input name="2" size="2" value="20" data-maximum="125" quantity="125" data-minimum="20" data-nmb="10" data-prc="0.8400" type="text" oninput="recalc(2);"> // здесь выполнются функции recalc -> mathC -> is.
</div>
<div class="price">
<span class="change-price2" price="0.8400">4.20USD</span> // здесь выводится результат recalc
</div>
function recalc(product_id) { // скрипт находится в отдельном файле и выполняется первым, а должен выполняться последним
var quantity = $('input[name="' + product_id + '"]').val();
var quantity = typeof(quantity) != 'undefined' ? quantity : 1;
var options_price = 0;
var price_no_format = Number($('.change-price'+product_id).attr('price'));
var special_no_format = Number($('.change-special'+product_id).attr('price'));
var new_price = (price_no_format + options_price) * quantity;
var new_special = (special_no_format + options_price) * quantity;
$('.change-price' + product_id).html(price_format(new_price)); // вывод значения после пересчета
$('.change-special' + product_id).html(price_format(new_special));
}
Последний раз редактировалось MixPetrov, 26.02.2017 в 23:44.
|
|
26.02.2017, 23:30
|
|
Профессор
|
|
Регистрация: 27.05.2010
Сообщений: 33,109
|
|
MixPetrov,
...
<!DOCTYPE html>
<html>
<head>
<title>Untitled</title>
<meta charset="utf-8">
<style type="text/css">
</style>
<script src="https://ajax.googleapis.com/ajax/libs/jquery/1.12.4/jquery.min.js"></script>
<script>
$(function() {
$(".quantity_cart").each(function(indx, el) {
var input = $("input", el)[0];
var nmb = +input.dataset.nmb;
var value = +input.value;
var maximum = +input.dataset.maximum;
var minimum = +input.dataset.minimum;
var prc = +input.dataset.prc;
function setValue() {
var ns = +input.value.replace(/\D/g, "") || 0;
ns = Math.ceil(ns / nmb) * nmb;
value = ns
}
function limit() {
return value = Math.min(Math.max(minimum, value), maximum)
}
function add(x) {
return value += x * nmb
}
var span = $("div.price").eq(indx).find("span");
function show() {
input.value = value;
var sum = (value * prc).toFixed(2) + "USD";
span.text(sum)
}
show();
var timer;
$(el).on("click", ".minus, .plus", function() {
var x = $(this).is(".minus") ? -1 : 1;
add(x);
limit();
show()
}).on("input", function() {
window.clearTimeout(timer);
timer = window.setTimeout(function() {
setValue();
limit();
show()
}, 1200)
})
})
});
</script>
</head>
<body>
<div class="quantity_cart">
<span class="minus" ><</span>
<input name="2" size="2" oninput="recalc(2);" value="20" data-maximum="120" data-minimum="20" data-nmb="10" data-prc="0.8400" type="text">
<span class="plus" >></span>
</div>
<div class="price">
<span class="change-price" ></span>
</div>
</body>
</html>
Последний раз редактировалось рони, 27.02.2017 в 00:17.
|
|
26.02.2017, 23:42
|
Аспирант
|
|
Регистрация: 12.10.2016
Сообщений: 53
|
|
Так и есть
|
|
27.02.2017, 00:11
|
|
Профессор
|
|
Регистрация: 27.05.2010
Сообщений: 33,109
|
|
MixPetrov,
медитируйте код выше и числа должны быть кратны data-nmb
|
|
27.02.2017, 02:45
|
Аспирант
|
|
Регистрация: 12.10.2016
Сообщений: 53
|
|
рони, Вы просто Бог в своем деле!
Подскажите как вычленить кусок из кода в котором происходит перемножение и подмена значения в <div class="price">
|
|
|
|