Я прочитал некоторые из предложенных вопросов, но я не уверен, как именно их реализовать:
У меня 8 текстовых полей, 7 используются для числового ввода, а 8-е - всего.
то есть 7,5 + 7,5 + 7,5 + 7,5 + 7,5 + 0,0 + 0,0 = 37,5
У меня есть jQuery, работающий так, что он отслеживает каждое keyup () textboxes, добавляет все значения и вычисляет итоговое значение.
Я решил, что хочу отформатировать ввод пользователя в 7 текстовых полях так, чтобы он выглядел как #. #, Если они вводят «1» или «.1», т.е. «1.0» или «0.1».
Проблема в том, что мне нужно добавить задержку перед форматированием ввода, и я не уверен, как мне это сделать с помощью javascript и / или jquery.
<script type="text/javascript">
$(function () {
var content = $('input[id*="txtMondayHours"]').val();
$('input[id*="txtMondayHours"]').keyup(function () {
if ($('input[id*="txtMondayHours"]').val() != content) {
content = $('input[id*="txtMondayHours"]').val();
$('input[id*="txtMondayHours"]').val((new Number($('input[id*="txtMondayHours"]').val())).toFixed(2));
var hoursMon = new Number(content);
var hoursTue = new Number($('input[id*="txtTuesdayHours"]').val());
var hoursWed = new Number($('input[id*="txtWednesdayHours"]').val());
var hoursThu = new Number($('input[id*="txtThursdayHours"]').val());
var hoursFri = new Number($('input[id*="txtFridayHours"]').val());
var hoursSat = new Number($('input[id*="txtSaturdayHours"]').val());
var hoursSun = new Number($('input[id*="txtSundayHours"]').val());
$('input[id*="txtTotalWorkingHours"]').val(parseFloat(hoursMon.toFixed(2)) + parseFloat(hoursTue.toFixed(2)) + parseFloat(hoursWed.toFixed(2)) + parseFloat(hoursThu.toFixed(2)) + parseFloat(hoursFri.toFixed(2)) + parseFloat(hoursSat.toFixed(2)) + parseFloat(hoursSun.toFixed(2)));
}
});
var content2 = $('input[id*="txtTuesdayHours"]').val();
$('input[id*="txtTuesdayHours"]').keyup(function () {
if ($('input[id*="txtTuesdayHours"]').val() != content2) {
content2 = $('input[id*="txtTuesdayHours"]').val();
var hoursMon = new Number(content2);
var hoursTue = new Number($('input[id*="txtMondayHours"]').val());
var hoursWed = new Number($('input[id*="txtWednesdayHours"]').val());
var hoursThu = new Number($('input[id*="txtThursdayHours"]').val());
var hoursFri = new Number($('input[id*="txtFridayHours"]').val());
var hoursSat = new Number($('input[id*="txtSaturdayHours"]').val());
var hoursSun = new Number($('input[id*="txtSundayHours"]').val());
$('input[id*="txtTotalWorkingHours"]').val(parseFloat(hoursMon.toFixed(2)) + parseFloat(hoursTue.toFixed(2)) + parseFloat(hoursWed.toFixed(2)) + parseFloat(hoursThu.toFixed(2)) + parseFloat(hoursFri.toFixed(2)) + parseFloat(hoursSat.toFixed(2)) + parseFloat(hoursSun.toFixed(2)));
}
});
var content3 = $('input[id*="txtWednesdayHours"]').val();
$('input[id*="txtWednesdayHours"]').keyup(function () {
if ($('input[id*="txtWednesdayHours"]').val() != content3) {
content3 = $('input[id*="txtWednesdayHours"]').val();
var hoursMon = new Number(content3);
var hoursTue = new Number($('input[id*="txtMondayHours"]').val());
var hoursWed = new Number($('input[id*="txtTuesdayHours"]').val());
var hoursThu = new Number($('input[id*="txtThursdayHours"]').val());
var hoursFri = new Number($('input[id*="txtFridayHours"]').val());
var hoursSat = new Number($('input[id*="txtSaturdayHours"]').val());
var hoursSun = new Number($('input[id*="txtSundayHours"]').val());
$('input[id*="txtTotalWorkingHours"]').val(parseFloat(hoursMon.toFixed(2)) + parseFloat(hoursTue.toFixed(2)) + parseFloat(hoursWed.toFixed(2)) + parseFloat(hoursThu.toFixed(2)) + parseFloat(hoursFri.toFixed(2)) + parseFloat(hoursSat.toFixed(2)) + parseFloat(hoursSun.toFixed(2)));
}
});
var content4 = $('input[id*="txtThursdayHours"]').val();
$('input[id*="txtThursdayHours"]').keyup(function () {
if ($('input[id*="txtThursdayHours"]').val() != content4) {
content4 = $('input[id*="txtThursdayHours"]').val();
var hoursMon = new Number(content4);
var hoursTue = new Number($('input[id*="txtMondayHours"]').val());
var hoursWed = new Number($('input[id*="txtTuesdayHours"]').val());
var hoursThu = new Number($('input[id*="txtWednesdayHours"]').val());
var hoursFri = new Number($('input[id*="txtFridayHours"]').val());
var hoursSat = new Number($('input[id*="txtSaturdayHours"]').val());
var hoursSun = new Number($('input[id*="txtSundayHours"]').val());
$('input[id*="txtTotalWorkingHours"]').val(parseFloat(hoursMon.toFixed(2)) + parseFloat(hoursTue.toFixed(2)) + parseFloat(hoursWed.toFixed(2)) + parseFloat(hoursThu.toFixed(2)) + parseFloat(hoursFri.toFixed(2)) + parseFloat(hoursSat.toFixed(2)) + parseFloat(hoursSun.toFixed(2)));
}
});
var content5 = $('input[id*="txtFridayHours"]').val();
$('input[id*="txtFridayHours"]').keyup(function () {
if ($('input[id*="txtFridayHours"]').val() != content5) {
content5 = $('input[id*="txtFridayHours"]').val();
var hoursMon = new Number(content5);
var hoursTue = new Number($('input[id*="txtMondayHours"]').val());
var hoursWed = new Number($('input[id*="txtWednesdayHours"]').val());
var hoursThu = new Number($('input[id*="txtThursdayHours"]').val());
var hoursFri = new Number($('input[id*="txtTuesdayHours"]').val());
var hoursSat = new Number($('input[id*="txtSaturdayHours"]').val());
var hoursSun = new Number($('input[id*="txtSundayHours"]').val());
$('input[id*="txtTotalWorkingHours"]').val(parseFloat(hoursMon.toFixed(2)) + parseFloat(hoursTue.toFixed(2)) + parseFloat(hoursWed.toFixed(2)) + parseFloat(hoursThu.toFixed(2)) + parseFloat(hoursFri.toFixed(2)) + parseFloat(hoursSat.toFixed(2)) + parseFloat(hoursSun.toFixed(2)));
}
});
var content6 = $('input[id*="txtSaturdayHours"]').val();
$('input[id*="txtSaturdayHours"]').keyup(function () {
if ($('input[id*="txtSaturdayHours"]').val() != content6) {
content6 = $('input[id*="txtSaturdayHours"]').val();
var hoursMon = new Number(content6);
var hoursTue = new Number($('input[id*="txtMondayHours"]').val());
var hoursWed = new Number($('input[id*="txtWednesdayHours"]').val());
var hoursThu = new Number($('input[id*="txtThursdayHours"]').val());
var hoursFri = new Number($('input[id*="txtFridayHours"]').val());
var hoursSat = new Number($('input[id*="txtTuesdayHours"]').val());
var hoursSun = new Number($('input[id*="txtSundayHours"]').val());
$('input[id*="txtTotalWorkingHours"]').val(parseFloat(hoursMon.toFixed(2)) + parseFloat(hoursTue.toFixed(2)) + parseFloat(hoursWed.toFixed(2)) + parseFloat(hoursThu.toFixed(2)) + parseFloat(hoursFri.toFixed(2)) + parseFloat(hoursSat.toFixed(2)) + parseFloat(hoursSun.toFixed(2)));
}
});
var content7 = $('input[id*="txtSundayHours"]').val();
$('input[id*="txtSundayHours"]').keyup(function () {
if ($('input[id*="txtSundayHours"]').val() != content7) {
content7 = $('input[id*="txtSundayHours"]').val();
var hoursMon = new Number(content7);
var hoursTue = new Number($('input[id*="txtMondayHours"]').val());
var hoursWed = new Number($('input[id*="txtWednesdayHours"]').val());
var hoursThu = new Number($('input[id*="txtThursdayHours"]').val());
var hoursFri = new Number($('input[id*="txtFridayHours"]').val());
var hoursSat = new Number($('input[id*="txtSaturdayHours"]').val());
var hoursSun = new Number($('input[id*="txtTuesdayHours"]').val());
$('input[id*="txtTotalWorkingHours"]').val(parseFloat(hoursMon.toFixed(2)) + parseFloat(hoursTue.toFixed(2)) + parseFloat(hoursWed.toFixed(2)) + parseFloat(hoursThu.toFixed(2)) + parseFloat(hoursFri.toFixed(2)) + parseFloat(hoursSat.toFixed(2)) + parseFloat(hoursSun.toFixed(2)));
}
});
});
</script>
В идеале я хотел бы запустить эту строку:
$('input[id*="txtMondayHours"]').val((new Number($('input[id*="txtMondayHours"]').val())).toFixed(2));
По истечении указанного времени, например, 100мс
Обновлен рабочий код:
<script type="text/javascript">
var delay = (function () {
var timer = 0;
return function (callback, ms) {
clearTimeout(timer);
timer = setTimeout(callback, ms);
};
})();
$(function () {
var content = $('input[id*="txtMondayHours"]').val();
$('input[id*="txtMondayHours"]').keyup(function () {
if ($('input[id*="txtMondayHours"]').val() != content) {
content = $('input[id*="txtMondayHours"]').val();
var hoursMon = new Number(content);
var hoursTue = new Number($('input[id*="txtTuesdayHours"]').val());
var hoursWed = new Number($('input[id*="txtWednesdayHours"]').val());
var hoursThu = new Number($('input[id*="txtThursdayHours"]').val());
var hoursFri = new Number($('input[id*="txtFridayHours"]').val());
var hoursSat = new Number($('input[id*="txtSaturdayHours"]').val());
var hoursSun = new Number($('input[id*="txtSundayHours"]').val());
$('input[id*="txtTotalWorkingHours"]').val(parseFloat(hoursMon.toFixed(2)) + parseFloat(hoursTue.toFixed(2)) + parseFloat(hoursWed.toFixed(2)) + parseFloat(hoursThu.toFixed(2)) + parseFloat(hoursFri.toFixed(2)) + parseFloat(hoursSat.toFixed(2)) + parseFloat(hoursSun.toFixed(2)));
delay(function () {
$('input[id*="txtMondayHours"]').val((new Number($('input[id*="txtMondayHours"]').val())).toFixed(2));
}, 750);
}
});
var content2 = $('input[id*="txtTuesdayHours"]').val();
$('input[id*="txtTuesdayHours"]').keyup(function () {
if ($('input[id*="txtTuesdayHours"]').val() != content2) {
content2 = $('input[id*="txtTuesdayHours"]').val();
var hoursMon = new Number(content2);
var hoursTue = new Number($('input[id*="txtMondayHours"]').val());
var hoursWed = new Number($('input[id*="txtWednesdayHours"]').val());
var hoursThu = new Number($('input[id*="txtThursdayHours"]').val());
var hoursFri = new Number($('input[id*="txtFridayHours"]').val());
var hoursSat = new Number($('input[id*="txtSaturdayHours"]').val());
var hoursSun = new Number($('input[id*="txtSundayHours"]').val());
$('input[id*="txtTotalWorkingHours"]').val(parseFloat(hoursMon.toFixed(2)) + parseFloat(hoursTue.toFixed(2)) + parseFloat(hoursWed.toFixed(2)) + parseFloat(hoursThu.toFixed(2)) + parseFloat(hoursFri.toFixed(2)) + parseFloat(hoursSat.toFixed(2)) + parseFloat(hoursSun.toFixed(2)));
delay(function () {
$('input[id*="txtTuesdayHours"]').val((new Number($('input[id*="txtTuesdayHours"]').val())).toFixed(2));
}, 750);
}
});
var content3 = $('input[id*="txtWednesdayHours"]').val();
$('input[id*="txtWednesdayHours"]').keyup(function () {
if ($('input[id*="txtWednesdayHours"]').val() != content3) {
content3 = $('input[id*="txtWednesdayHours"]').val();
var hoursMon = new Number(content3);
var hoursTue = new Number($('input[id*="txtMondayHours"]').val());
var hoursWed = new Number($('input[id*="txtTuesdayHours"]').val());
var hoursThu = new Number($('input[id*="txtThursdayHours"]').val());
var hoursFri = new Number($('input[id*="txtFridayHours"]').val());
var hoursSat = new Number($('input[id*="txtSaturdayHours"]').val());
var hoursSun = new Number($('input[id*="txtSundayHours"]').val());
$('input[id*="txtTotalWorkingHours"]').val(parseFloat(hoursMon.toFixed(2)) + parseFloat(hoursTue.toFixed(2)) + parseFloat(hoursWed.toFixed(2)) + parseFloat(hoursThu.toFixed(2)) + parseFloat(hoursFri.toFixed(2)) + parseFloat(hoursSat.toFixed(2)) + parseFloat(hoursSun.toFixed(2)));
delay(function () {
$('input[id*="txtWednesdayHours"]').val((new Number($('input[id*="txtWednesdayHours"]').val())).toFixed(2));
}, 750);
}
});
var content4 = $('input[id*="txtThursdayHours"]').val();
$('input[id*="txtThursdayHours"]').keyup(function () {
if ($('input[id*="txtThursdayHours"]').val() != content4) {
content4 = $('input[id*="txtThursdayHours"]').val();
var hoursMon = new Number(content4);
var hoursTue = new Number($('input[id*="txtMondayHours"]').val());
var hoursWed = new Number($('input[id*="txtTuesdayHours"]').val());
var hoursThu = new Number($('input[id*="txtWednesdayHours"]').val());
var hoursFri = new Number($('input[id*="txtFridayHours"]').val());
var hoursSat = new Number($('input[id*="txtSaturdayHours"]').val());
var hoursSun = new Number($('input[id*="txtSundayHours"]').val());
$('input[id*="txtTotalWorkingHours"]').val(parseFloat(hoursMon.toFixed(2)) + parseFloat(hoursTue.toFixed(2)) + parseFloat(hoursWed.toFixed(2)) + parseFloat(hoursThu.toFixed(2)) + parseFloat(hoursFri.toFixed(2)) + parseFloat(hoursSat.toFixed(2)) + parseFloat(hoursSun.toFixed(2)));
delay(function () {
$('input[id*="txtThursdayHours"]').val((new Number($('input[id*="txtThursdayHours"]').val())).toFixed(2));
}, 750);
}
});
var content5 = $('input[id*="txtFridayHours"]').val();
$('input[id*="txtFridayHours"]').keyup(function () {
if ($('input[id*="txtFridayHours"]').val() != content5) {
content5 = $('input[id*="txtFridayHours"]').val();
var hoursMon = new Number(content5);
var hoursTue = new Number($('input[id*="txtMondayHours"]').val());
var hoursWed = new Number($('input[id*="txtWednesdayHours"]').val());
var hoursThu = new Number($('input[id*="txtThursdayHours"]').val());
var hoursFri = new Number($('input[id*="txtTuesdayHours"]').val());
var hoursSat = new Number($('input[id*="txtSaturdayHours"]').val());
var hoursSun = new Number($('input[id*="txtSundayHours"]').val());
$('input[id*="txtTotalWorkingHours"]').val(parseFloat(hoursMon.toFixed(2)) + parseFloat(hoursTue.toFixed(2)) + parseFloat(hoursWed.toFixed(2)) + parseFloat(hoursThu.toFixed(2)) + parseFloat(hoursFri.toFixed(2)) + parseFloat(hoursSat.toFixed(2)) + parseFloat(hoursSun.toFixed(2)));
delay(function () {
$('input[id*="txtFridayHours"]').val((new Number($('input[id*="txtFridayHours"]').val())).toFixed(2));
}, 750);
}
});
var content6 = $('input[id*="txtSaturdayHours"]').val();
$('input[id*="txtSaturdayHours"]').keyup(function () {
if ($('input[id*="txtSaturdayHours"]').val() != content6) {
content6 = $('input[id*="txtSaturdayHours"]').val();
var hoursMon = new Number(content6);
var hoursTue = new Number($('input[id*="txtMondayHours"]').val());
var hoursWed = new Number($('input[id*="txtWednesdayHours"]').val());
var hoursThu = new Number($('input[id*="txtThursdayHours"]').val());
var hoursFri = new Number($('input[id*="txtFridayHours"]').val());
var hoursSat = new Number($('input[id*="txtTuesdayHours"]').val());
var hoursSun = new Number($('input[id*="txtSundayHours"]').val());
$('input[id*="txtTotalWorkingHours"]').val(parseFloat(hoursMon.toFixed(2)) + parseFloat(hoursTue.toFixed(2)) + parseFloat(hoursWed.toFixed(2)) + parseFloat(hoursThu.toFixed(2)) + parseFloat(hoursFri.toFixed(2)) + parseFloat(hoursSat.toFixed(2)) + parseFloat(hoursSun.toFixed(2)));
delay(function () {
$('input[id*="txtSaturdayHours"]').val((new Number($('input[id*="txtSaturdayHours"]').val())).toFixed(2));
}, 750);
}
});
var content7 = $('input[id*="txtSundayHours"]').val();
$('input[id*="txtSundayHours"]').keyup(function () {
if ($('input[id*="txtSundayHours"]').val() != content7) {
content7 = $('input[id*="txtSundayHours"]').val();
var hoursMon = new Number(content7);
var hoursTue = new Number($('input[id*="txtMondayHours"]').val());
var hoursWed = new Number($('input[id*="txtWednesdayHours"]').val());
var hoursThu = new Number($('input[id*="txtThursdayHours"]').val());
var hoursFri = new Number($('input[id*="txtFridayHours"]').val());
var hoursSat = new Number($('input[id*="txtSaturdayHours"]').val());
var hoursSun = new Number($('input[id*="txtTuesdayHours"]').val());
$('input[id*="txtTotalWorkingHours"]').val(parseFloat(hoursMon.toFixed(2)) + parseFloat(hoursTue.toFixed(2)) + parseFloat(hoursWed.toFixed(2)) + parseFloat(hoursThu.toFixed(2)) + parseFloat(hoursFri.toFixed(2)) + parseFloat(hoursSat.toFixed(2)) + parseFloat(hoursSun.toFixed(2)));
delay(function () {
$('input[id*="txtSundayHours"]').val((new Number($('input[id*="txtSundayHours"]').val())).toFixed(2));
}, 750);
}
});
});
</script>