바라기의 이야기

필수값 체크 JS 1차버전... 본문

Develop/Javascript

필수값 체크 JS 1차버전...

baragi76 2011. 9. 23. 17:20

오류라던지... 어려가지 경우의 수에 따라서 적용할 수 있는 필수값 체크 JS 함수를 한번 만들어보자...
1차버전... 일단 여기서부터 시작해서 업그레이드 해나가도록 해야겠다...

아래는 어떤 프로젝트에서 적용해 놨던 코드 일부분 입니다...

var vMasterHolder = "ctl00_FormMaster_";

/********************************************************************************************
  함수명      : fn_ValidCheck()
  작성목적    : 문서 필수입력 데이터 체크.
  작성자      : ***
  최초작성일  : 
  ********************************************************************************************/
  function fn_ValidCheck() {
   //debugger;
   var vDocStatus = document.getElementById(vMasterHolder + "hfDocStatus").value;
   var checkItem;   // 체크할 필드
   var checkStatus;  // 상태값 분리
   var showInfoMsg;  // 메시지
   var radioCheck;   // 라디오 필드 체크용

   // 상태별로 체크해야 하는 필드를 정의한다.
   // vFields.push({ name: "<경고표시 필드명>", field: "<필드명>", status: "<상태값 세미콜론(;)구분>", type: "<필드타입 text,dropdown, radio>" });
   var vFields = new Array();
   vFields.push({ name: "<asp:Literal runat='server' Text='<%$ Resources:JobGoal.Text %>' />", field: "JobGoal", status: "selfdraft", type: "text" });
   vFields.push({ name: "<asp:Literal runat='server' Text='<%$ Resources:DesSelf.Text %>' />", field: "EvalValuer0_1", status: "selfdraft", type: "dropdown" });
   vFields.push({ name: "<asp:Literal runat='server' Text='<%$ Resources:DesSelf.Text %>' />", field: "EvalValuer0_2", status: "selfdraft", type: "dropdown" });
   vFields.push({ name: "<asp:Literal runat='server' Text='<%$ Resources:AchievementEvaluate.Text %>' />", field: "Capability", status: "selfdraft", type: "text" });
   vFields.push({ name: "<asp:Literal runat='server' Text='<%$ Resources:DesFirst.Text %>' />", field: "EvalValuer1_1", status: "firstdraft", type: "dropdown" });
   vFields.push({ name: "<asp:Literal runat='server' Text='<%$ Resources:DesFirst.Text %>' />", field: "EvalValuer1_2", status: "firstdraft", type: "dropdown" });
   vFields.push({ name: "<asp:Literal runat='server' Text='<%$ Resources:TotalEvaluate.Text %>' />", field: "Eval2_Valuer2_7", status: "seconddraft", type: "dropdown" });
   vFields.push({ name: "<asp:Literal runat='server' Text='<%$ Resources:TotalEvaluate.Text %>' />", field: "Eval2_Valuer2_ContractState_7", status: "seconddraft", type: "radio" });
   vFields.push({ name: "<asp:Literal runat='server' Text='<%$ Resources:TotalEvaluate.Text %>' />", field: "Eval3_Valuer3_7", status: "thirddraft", type: "dropdown" });
   vFields.push({ name: "<asp:Literal runat='server' Text='<%$ Resources:TotalEvaluate.Text %>' />", field: "Eval3_Valuer3_ContractState_7", status: "thirddraft", type: "radio" });

   for (var i = 0; i < vFields.length; i++) {
    checkItem = document.getElementById(vMasterHolder + vFields[i].field);
    checkStatus = vFields[i].status.split(';');

    // 복수 상태값에 대한 처리
    for (var j = 0; j < checkStatus.length; j++) {
     try {
      if (vDocStatus == checkStatus[j]) {
       if (checkItem) {
        // 필드 타입이 입력
        if (vFields[i].type == "text") {
         if (checkItem.value == "") {
          showInfoMsg = vFields[i].name + " <asp:Literal runat='server' Text='<%$ Resources:MsgInputValidation.Text %>' />";
          checkItem.focus();
          //alert(showInfoMsg);
          fn_ShowInfoMessageStr(escape(showInfoMsg));
          return false;
         }
        }
        else if (vFields[i].type == "dropdown") {
         if (checkItem.selectedIndex == null || checkItem.selectedIndex == undefined || checkItem.selectedIndex == 0) {
          showInfoMsg = vFields[i].name + " <asp:Literal runat='server' Text='<%$ Resources:MsgSelectValidation.Text %>' />";
          checkItem.focus();
          //alert(showInfoMsg);
          fn_ShowInfoMessageStr(escape(showInfoMsg));
          return false;
         }
        }
        else if (vFields[i].type == "radio") {
         radioCheck = false;
         for (var k = 0; k < checkItem.childNodes[0].childNodes.length; k++) {
          radioCheck = radioCheck || document.getElementById(checkItem.id + "_" + k).checked;
          if (radioCheck)
           break;
         }
         if (!radioCheck) {
          showInfoMsg = vFields[i].name + " <asp:Literal runat='server' Text='<%$ Resources:MsgSelectValidation.Text %>' />";
          document.getElementById(checkItem.id + "_0").focus();
          //alert(showInfoMsg);
          fn_ShowInfoMessageStr(escape(showInfoMsg));
          return false;
         }
        }
       }
      }
     } catch (e) { }
    }
   }

   return true;
  }