체크박스 다중체크 필수 유효성 폼메일 질문드립니다

매출이 오르면 내리는 수수료! 지금 수수료센터에서 전자결제(PG)수수료 비교견적 신청해 보세요!
체크박스 다중체크 필수 유효성 폼메일 질문드립니다

QA

체크박스 다중체크 필수 유효성 폼메일 질문드립니다

본문

아래는 폼메일에 적용된 체크박스 입니다

 

그룹1

<input type='checkbox' id='a1' name='a1[]' value='선택1'>

<input type='checkbox' id='a1' name='a1[]' value='선택2'>

 

그룹2

<input type='checkbox' id='a2' name='a2[]' value='선택1'>

<input type='checkbox' id='a2' name='a2[]' value='선택2'>

 

그룹3

<input type='checkbox' id='a3' name='a3[]' value='선택1'>

<input type='checkbox' id='a3' name='a3[]' value='선택2'>

 

위 체크박스 각 그룹에서

필수 1개씩 무조건 선택하도록 하고싶는데요

 

 

아래는 검색해서 나온 답변중에서 적용해봤는데

그룹1은 잘 되는데

그룹2..그룹3은 어떤식으로 확장해서 추가해야하는지

여러가지방법을 해봐도 잘 안되네요

 

고수님들 도와주세요!

감사합니다!

 

 

-JavaScript-

function chkMailFrm(f) {
  var checked = document.querySelectorAll('[name="a1[]"]:checked');
  if ( !checked.length ) {
    alert("체크박스 하나 이상 선택해주세요.");
    return false;
  } 
  return true;
}

 

 

이 질문에 댓글 쓰기 :

답변 2


<form>
  <div>그룹1</div>
  <div>그룹2</div>
  <div>그룹3</div>
</form>

<script>
const form = document.querySelector('form');
 
form.addEventListener('submit', (event) => {
  // 각 그룹의 체크박스가 선택되었는지 확인
  const groups = document.querySelectorAll('div');
  for (const group of groups) {
    const checkedBoxes = group.querySelectorAll('input[type="checkbox"]:checked');
    if (checkedBoxes.length === 0) {
      alert('각 그룹에서 최소 하나의 체크박스를 선택하세요.');
      event.preventDefault(); // 폼 제출 중단
      return;
    }
  }
});
</script>

다음 코드가 도움이 될지 모르겠습니다.

 


<style>
input[type="checkbox"][name$="\[\]"]:focus {
  outline: 0.2em dashed gray;
  outline-offset: 0.2em;
}
</style>
 
<script>
function chkMailFrm(f) {
  // var checked = document.querySelectorAll('[name="a1[]"]:checked');
  // if ( !checked.length ) {
  //   alert("체크박스 하나 이상 선택해주세요.");
  //   return false;
  // } 
  // return true;

  let passed = true;
 
  const chk_name_map = {};
  f.querySelectorAll('input[type="checkbox"][name$="\[\]"]').forEach((el, i) => {
    const el_name_prefix = el.name.substring(0, 2);
    if (chk_name_map[el_name_prefix] == null) {
      chk_name_map[el_name_prefix] = [];
    }
    chk_name_map[el_name_prefix].push(el);
  });
 
  for (const [k, arr] of Object.entries(chk_name_map)) {
    let chkd = false;
    for (let i = 0, i_len = arr.length; i < i_len; i++) {
      if (arr[i].checked == true) {
        chkd = true;
        break;
      }
    }
 
    if (chkd == false) {
      passed = false;
      alert(k + ' group need a choice');
      arr[0].focus();
      break;
    }
  }
 
  if (passed == false) {
    return false;
  }
 
  return true;
}
</script>
 
<form onsubmit="return chkMailFrm(this)">
그룹1
<input type='checkbox' name='a1[]' value='선택1'>
<input type='checkbox' name='a1[]' value='선택2'>
 
그룹2
<input type='checkbox' name='a2[]' value='선택1'>
<input type='checkbox' name='a2[]' value='선택2'>
 
그룹3
<input type='checkbox' name='a3[]' value='선택1'>
<input type='checkbox' name='a3[]' value='선택2'>

<button type="submit">submit</button>
</form>

답변감사합니다! 바로 적용해 봤는데요.
그룹1은 체크가 없으면 체크하라고 검사를 하지만
그룹2, 그룹3은 체크가 없는데도 체크하라고 경고창 안뜨고 바로 전송이 되네요
제가 뭘 놓친건지 어렵 ㅠㅠ

답변을 작성하시기 전에 로그인 해주세요.
전체 4
QA 내용 검색

회원로그인

(주)에스아이알소프트 / 대표:홍석명 / (06211) 서울특별시 강남구 역삼동 707-34 한신인터밸리24 서관 1404호 / E-Mail: admin@sir.kr
사업자등록번호: 217-81-36347 / 통신판매업신고번호:2014-서울강남-02098호 / 개인정보보호책임자:김민섭(minsup@sir.kr)
© SIRSOFT