PGR21.com
- PGR21 관련된 질문 및 건의는 [건의 게시판]을 이용바랍니다.
- (2013년 3월 이전) 오래된 질문글은 [이전 질문 게시판]에 있습니다.
통합 규정을 준수해 주십시오. (2015.12.25.)
Date 2022/08/05 15:16:22
Name Mindow
Subject [질문] [vue js] vue 초보질문. 라디오버튼으로 탭효과 (수정됨)
vue js 초보입니다

vue js 환경에서 라디오 버튼으로 탭효과 처리를 만들어봤는데요

라디오 버튼이 3개가 있고 라디오 버튼 클릭하면 하단에 그에 맞는 박스가 노출되는 형태입니다

노출되는 방법은 v-if 같은걸로 하진 않았고 박스에 멀티 클래스 제어하는 방식으로 했습니다.

(기본은 display: none; 클래스 show가 추가되면 display: block;)


코딩 후 빌드해서 페이지 로드했더니 현상이...
라디오버튼 2를 클릭하면 박스1,3은 미노출, 박스2만 노출되어야 정상인데
박스1노출, 박스2노출, 박스3 미노출 상태가 됩니다.
웃긴 건 두번째 클릭부터는 정상으로 작동합니다.

처음 페이지 로드 or 새로고침 했을 때
첫번째 클릭시 비정상적으로 작동하고 두번째 클릭부터는 정상 작동하네요

그리고 편집기에서 소스를 이 부분에 영향 없게 수정 (예를 들어 주석을 단더던지 전혀 다른 부분 수정을 한다던지)해서
브라우저가 자동으로 다시 읽을 땐 영향이 없습니다. 해당 페이지 첫 로드나 새로 고침때만 그렇네요


pgr 에디터 특성상 들여쓰기는 안 이쁜 채로 그냥 넣을게요 양해 부탁 ^^;


[html]

꺽쇠를 넣었더니 pgr 에디터에서 그대로 안 나와서 왼쪽 꺽쇠는  [ 로 오른쪽 꺽쇠는 ]로 대체해서 넣었습니다


[div class="c-form-radio-wrap"]
                  [div class="c-form-radio"]
                    [input type="radio" name="radio-name" id="radio-id1" value="radioValue1" v-model="radioModel"]
                    [label for="radio-id1"]라디오버튼1[/label]
                  [/div]
                  [div class="c-form-radio"]
                    [input type="radio" name="radio-name" id="radio-id2" value="radioValue2" v-model="radioModel"]
                    [label for="radio-id2"]라디오버튼2[/label]
                  [/div]
                  [div class="c-form-radio"]
                    [input type="radio" name="radio-name" id="radio-id3" value="radioValue3" v-model="radioModel"]
                    [label for="radio-id3"]라디오버튼3[/label]
                  [/div]
                [/div]


                [div class="box1 show"]box1[/div]
                [div class="box2"]box2[/div]
                [div class="box3"]box3[/div]





[스크립트]

export default {
  data() {
    return {
      radioModel: 'radioValue1'
    }
  },
  watch: {
      radioModel(data){
        const box1 = document.querySelector('.box1');
        const box2 = document.querySelector('.box2');
        const box3 = document.querySelector('.box3');
        if(data == "radioValue1") {
          box2.classList.remove('show');
          box3.classList.remove('show');
          box1.classList.add('show');
        }
        else if(data == "radioValue2") {
          box1.classList.remove('show');
          box3.classList.remove('show');
          box2.classList.add('show');
        }
        else if(data == "radioValue3") {
          box1.classList.remove('show');
          box2.classList.remove('show');
          box3.classList.add('show');
        }
      }
    }
}




========================

원인이 무엇일까요

통합규정 1.3 이용안내 인용

"Pgr은 '명문화된 삭제규정'이 반드시 필요하지 않은 분을 환영합니다.
법 없이도 사는 사람, 남에게 상처를 주지 않으면서 같이 이야기 나눌 수 있는 분이면 좋겠습니다."
22/08/05 15:39
수정 아이콘
(수정됨) <div class="box1" :class="{'show' : radioModel === 'radioValue1'}">box1</div>
<div class="box2" :class="{'show' : radioModel === 'radioValue2'}">box2</div>
<div class="box3" :class="{'show' : radioModel === 'radioValue2'}">box3</div>
이렇게 바꾸시면 스크립트 부분의 watch는 필요 없어집니다.
저렇게 dom의 클래스로 접근해서 스타일을 제어하는 방식은 추천드리지 않아요

https://codepen.io/zealiath/pen/LYdmVee 이렇게만 하셔도 됩니다.
22/08/05 16:19
수정 아이콘
답변 감사합니다~! 해결되었어요~
목록 삭게로! 맨위로
번호 제목 이름 날짜 조회
165274 [질문] 이사비용 95만원 나왔는데 싼 건가요? 비싼건가요? [19] 그때가언제라도5920 22/08/05 5920
165273 [질문] 자게 신고 5건으로 글이 잠기는 것 어떻게 생각하시나요? [15] Dresden5301 22/08/05 5301
165272 [질문] 노트북 중고거래 이가격 괜찮은가요? [13] 코봉이7470 22/08/05 7470
165271 [질문] 친형 결혼식에 입을 옷 추천 부탁 드립니다 [18] 호아킨6057 22/08/05 6057
165270 [질문] [vue js] vue 초보질문. 라디오버튼으로 탭효과 [2] Mindow3283 22/08/05 3283
165269 [질문] 뻘질문) 삼국지 vs 롤 전세계 인지도 [20] 자존감5536 22/08/05 5536
165268 [질문] 컴퓨터 CPU업그레이드 관련질문드립니다~ [20] 메이블링5752 22/08/05 5752
165267 [질문] 동네 친구를 사귈 수 있는 방법이 있나요? [25] onDemand8849 22/08/05 8849
165266 [질문] 국내 여행지 추천 부탁드립니다. [5] 유유할때유4312 22/08/05 4312
165265 [질문] 미드 아우터 레인지 재밌나요? [1] 실제상황입니다4088 22/08/05 4088
165264 [질문] 일정 조건(?)의 기계식 키보드 추천부탁드립니다 [14] AKbizs5642 22/08/05 5642
165263 [질문] 마통 금리 관련으로 문의 드립니다 [7] 메타몽6836 22/08/05 6836
165262 [질문] 솔직히 부모님들 아이폰 힘들겠죠? [38] CastorPollux7286 22/08/05 7286
165261 [질문] 블루투스 이어폰 추천 부탁드립니다. [3] 엄마 사랑해요5602 22/08/05 5602
165260 [질문] 아이폰 카카오톡 저장 질문 드립니다 [2] plhs4604 22/08/05 4604
165259 [질문] 오늘 우영우 에피소드 무슨 내용이였나요? [26] 건방진고양이7826 22/08/05 7826
165258 [질문] 전자책 추천 부탁드립니다. [7] SkyClouD5978 22/08/04 5978
165257 [질문] 책상과 모니터암을 분리(?) 시키고 싶습니다. [9] AKbizs6352 22/08/04 6352
165256 [질문] 소용돌이 문양에 대해 질문드립니다 [16] Azzal5614 22/08/04 5614
165255 [질문] 운동 시간이 고민입니다 (하루에 머리 두번 감으면 탈모?) [8] 따루라라랑7273 22/08/04 7273
165254 [질문] 서울 마사지 잘하는 업소 찾습니다. [9] giants7252 22/08/04 7252
165253 [삭제예정] 롤 중에 있었던 채팅 내역을 게임 끝나고 확인할 방법이 있을까요? [1] 환경미화6585 22/08/04 6585
165252 [질문] 1억을 은행에 예금해두면 이자가 다달이 나오나요? [8] This-Plus6026 22/08/04 6026
목록 이전 다음
댓글

+ : 최근 1시간내에 달린 댓글
+ : 최근 2시간내에 달린 댓글
맨 위로