いくつかの必須フィールドを持つフォームがあります。これらのフィールドは、ドロップダウンを除いてすべて機能します。必須のドロップダウンの問題
私はフィールドをチェックするために、このコードを使用しています:私は、ユーザーを作るために行方不明です何
<select name="country" id="country">
<option value="" disabled="disabled">Please select your country</option>
<option value="United Kingdom">United Kingdom</option>
<option value="United States">United States</option>
...
:
function formCheck(formobj){
// Enter name of mandatory fields
var fieldRequired = Array("name", "country", "email", "tel");
// Enter field description to appear in the dialog box
var fieldDescription = Array("Name", "Country", "Email", "Telephone");
// dialog message
var alertMsg = "Please complete the following fields:\n";
var l_Msg = alertMsg.length;
for (var i = 0; i < fieldRequired.length; i++){
var obj = formobj.elements[fieldRequired[i]];
if (obj){
switch(obj.type){
case "select-one":
if (obj.selectedIndex == -1 || obj.options[obj.selectedIndex].text == ""){
alertMsg += " - " + fieldDescription[i] + "\n";
}
break;
case "select-multiple":
if (obj.selectedIndex == -1){
alertMsg += " - " + fieldDescription[i] + "\n";
}
break;
case "text":
case "textarea":
if (obj.value == "" || obj.value == null){
alertMsg += " - " + fieldDescription[i] + "\n";
}
break;
default:
}
if (obj.type == undefined){
var blnchecked = false;
for (var j = 0; j < obj.length; j++){
if (obj[j].checked){
blnchecked = true;
}
}
if (!blnchecked){
alertMsg += " - " + fieldDescription[i] + "\n";
}
}
}
}
if (alertMsg.length == l_Msg){
return true;
}else{
alert(alertMsg);
return false;
}
}
これは私がドロップダウンのために使っていたコードです「国を選択してください」と表示されていて、何も返されていない国を選択してください。
ホイールを再開発するのではなく、jQueryのようなjavascriptライブラリを使用することをお勧めします。ブラウザ間の違いを扱う、信頼性の高い堅牢なコードが得られます。 – RedFilter
@RedFilter:コードブロック全体を10 LLOCに減らすことはできません。 –