みんなとギャル私は数字と小数点以下1桁しか許可しないこのJavaScriptコードを持っています。私が抱えている問題は、テキストボックスコントロールにタブで移動すると値が強調表示されますが、バックスペースを押して消去してから数値を入力する必要があることです。それは私が防ぎたい余分なキーストロークです。
それを作成した人への小道具が見つかり(http://www.coderanch.com/t/114528/HTML-CSS-JavaScript/decimal-point-restriction)、ここにコードがあります。これをkeyUpイベントに入れました。
<script>
// Retrieve last key pressed. Works in IE and Netscape.
// Returns the numeric key code for the key pressed.
function getKey(e)
{
if (window.event)
return window.event.keyCode;
else if (e)
return e.which;
else
return null;
}
function restrictChars(e, obj)
{
var CHAR_AFTER_DP = 2; // number of decimal places
var validList = "0123456789."; // allowed characters in field
var key, keyChar;
key = getKey(e);
if (key == null) return true;
// control keys
// null, backspace, tab, carriage return, escape
if ( key==0 || key==8 || key==9 || key==13 || key==27 )
return true;
// get character
keyChar = String.fromCharCode(key);
// check valid characters
if (validList.indexOf(keyChar) != -1)
{
// check for existing decimal point
var dp = 0;
if( (dp = obj.value.indexOf( ".")) > -1)
{
if( keyChar == ".")
return false; // only one allowed
else
{
// room for more after decimal point?
if( obj.value.length - dp <= CHAR_AFTER_DP)
return true;
}
}
else return true;
}
// not a valid character
return false;
}
</script>