6桁の後にダッシュを自動的に追加する入力フィールドを作成するにはどうすればよいですか。また、入力フィールドに数字を書き込むことのみが可能である必要があります。
これはjQueryを使用して実行できますか?
6桁の後にダッシュを自動的に追加する入力フィールドを作成するにはどうすればよいですか。また、入力フィールドに数字を書き込むことのみが可能である必要があります。
これはjQueryを使用して実行できますか?
この投稿からのコードの借用:jQueryを使用してHTML入力ボックスで数値(0〜9)のみを許可するにはどうすればよいですか?
長さをキャプチャする条件を追加できます。
<script src="//ajax.googleapis.com/ajax/libs/jquery/1.8.2/jquery.min.js"></script>
<script src="//ajax.googleapis.com/ajax/libs/jqueryui/1.9.0/jquery-ui.min.js"></script>
<script>
$(document).ready(function() {
$("#txtboxToFilter").keydown(function(event) {
// Allow: backspace, delete, tab, escape, and enter
if ( event.keyCode == 46 || event.keyCode == 8 || event.keyCode == 9 || event.keyCode == 27 || event.keyCode == 13 ||
// Allow: Ctrl+A
(event.keyCode == 65 && event.ctrlKey === true) ||
// Allow: home, end, left, right
(event.keyCode >= 35 && event.keyCode <= 39)) {
return;
}
else {
// Ensure that it is a number and stop the keypress
if (event.shiftKey || (event.keyCode < 48 || event.keyCode > 57) && (event.keyCode < 96 || event.keyCode > 105 )) {
event.preventDefault();
}
}
if( $("#txtboxToFilter").val().length == 6 )
{
event.target.value = event.target.value + "-";
}
});
});
</script>
<form>
<input type="text" id="txtboxToFilter">
</form>
jQuery('#inputFieldId').keydown(function(event) {
var enteredValue = jQuery(this).val();
if ( event.keyCode == 46 || event.keyCode == 8 || event.keyCode == 9 || event.keyCode == 27 || event.keyCode == 13 ||
(event.keyCode == 65 && event.ctrlKey === true) || (event.keyCode >= 35 && event.keyCode <= 39) ||
(event.keyCode>=48 && event.keyCode<=57) || (event.keyCode>=96 && event.keyCode<=105)) // allow numbers
{
if(enteredValue.length==6 && ((event.keyCode>=48 && event.keyCode<=57) || (event.keyCode>=96 && event.keyCode<=105)))
{
jQuery(this).val(enteredValue+"-")
}
}
else
{
event.preventDefault();
}
});
コードを修正しました。これを試してください。