デフォルトの入力文字セットを携帯電話の数字に設定する入力フィールドを作成することは可能ですか(したがってNUMERICAL KEYBOARD POPS UP )?
たとえば、電話番号を HTML フォームに簡単に入力できるようにします。
7 に答える
数字の入力を簡単にするには、を使用します<input type="number">
。電話番号の入力を簡単にするには、を使用します<input type="tel">
。すべての電話がそれらをサポートするわけではありませんが、iPhoneは少なくとも通常のキーボードの代わりにデフォルトで数字キーパッドを提供します。詳細については、仕様とDiveIntoHTML5を参照してください。
「携帯電話」でのエントリーを制限することが可能です 携帯電話フォームエントリーは、
<!DOCTYPE wml PUBLIC "-//WAPFORUM//DTD WML 1.1//EN"
"http://www.wapforum.org/DTD/wml_1.1.xml">
ここでの入力は、format="*N" を使用して制限できます
使用できます<input type='tel'>
。これは HTML5 の新しい機能です。古いブラウザでは、テキスト入力フィールドがデフォルトになります。
したがって、またはのいずれかを使用できtype="tel"
ますtype="numbers"
。
違いは、電話のダイヤルキーボードを起動しようとする場合と、モバイルキーボードの数字入力に切り替えるだけの場合です。
JavaScript 言語を使用して、Web ページのテキスト入力要素の値のクロスブラウザー フィルターの私のプロジェクトを参照してください:入力キー フィルター。コード例:
<!doctype html>
<html xmlns="http://www.w3.org/1999/xhtml" >
<head>
<title>Input Key Filter Test</title>
<meta name="author" content="Andrej Hristoliubov anhr@mail.ru">
<meta http-equiv="Content-Type" content="text/html; charset=utf-8"/>
<!-- For compatibility of IE browser with audio element in the beep() function.
https://www.modern.ie/en-us/performance/how-to-use-x-ua-compatible -->
<meta http-equiv="X-UA-Compatible" content="IE=9"/>
<link rel="stylesheet" href="https://rawgit.com/anhr/InputKeyFilter/master/InputKeyFilter.css" type="text/css">
<script type="text/javascript" src="https://rawgit.com/anhr/InputKeyFilter/master/Common.js"></script>
<script type="text/javascript" src="https://rawgit.com/anhr/InputKeyFilter/master/InputKeyFilter.js"></script>
</head>
<body>
<h1>Phone number</h1>
Please type a phone number in the +**(***)***-**-** format. Example: +1(23)456-78-90
<br/>
<input id="PhoneNumber" value="+()--">
<script>
function getArrayPhoneNumber(value){
if (typeof value == 'undefined')
value = document.getElementById("PhoneNumber").value;
return value.match(/^(\+?\d*)\((\d*)\)(\d*)-?(\d*)-?(\d*)$/);
}
function getPhoneNumber(){
var arrayPhoneNumber = getArrayPhoneNumber();
if(!arrayPhoneNumber)
return "";
var phoneNumber = arrayPhoneNumber[1] + arrayPhoneNumber[2] + arrayPhoneNumber[3] + arrayPhoneNumber[4] + arrayPhoneNumber[5];
return phoneNumber;
}
inputKeyFilter.Create("PhoneNumber", function(event){//onChange event
inputKeyFilter.RemoveMyTooltip();
var arrayPhoneNumber = getArrayPhoneNumber();
if(!arrayPhoneNumber || (arrayPhoneNumber.length != 6)){
document.getElementById("NewPhoneNumber").innerHTML = "Incorrect format of the phone number";
return;
}
var elementNewPhoneNumber = document.getElementById("NewPhoneNumber");
var phoneNumber = getPhoneNumber();
if(inputKeyFilter.isNaN(phoneNumber, this)){
elementNewPhoneNumber.innerHTML = "";
return;
}
elementNewPhoneNumber.innerHTML = phoneNumber;
}
, function(elementInput, value){//customFilter
var arrayPhoneNumber = getArrayPhoneNumber(value);
if(arrayPhoneNumber == null){
inputKeyFilter.TextAdd(isRussian() ?
"Недопустимый формат телефонного номера. Например: +1(234)56-78-90"
: "Incorrect format of the phone number. Example: +1(234)56-78-90"
, elementInput);
if(elementInput.value == "")
elementInput.value = elementInput.defaultValue;
return false;
}
return true;
}
//onblur event. Use this function if you want set focus to the input element again if input value is NaN. (empty or invalid)
, function(event){ inputKeyFilter.isNaN(parseInt(getPhoneNumber()), this); }
);
</script>
New phone number: <span id="NewPhoneNumber"></span>
</body>
</html>
type="tel"
「またはのいずれかを使用できます」の私のテストのためにtype="numbers"
。iPhonetype="tel"
では、数字のみのキーパッド (電話など)type="numbers"
が表示され、数字と記号に切り替えられたテンキーパッドが表示されるため、両方とも機能しますが、アプリケーションによって異なります。私にとっては数字だけが必要なのでtype="tel"
、使いやすさのために使用しましたが、うまくいきました!
Javascript を使用した例を次に示します。これにより、テンキー/キーパッド上の数字、およびフォーマッター (シフト/バックスペース/など) からの数字のみが許可されます。また、サーバー側の検証だけでなく、誰かが数字以外をフィールドに貼り付けた場合にsetTimeout()
備えてイベントをチェックするために、数秒のタイムアウトで を追加することも検討してください。onchange