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
수정 아이콘
답변 감사합니다~! 해결되었어요~
목록 삭게로! 맨위로
번호 제목 이름 날짜 조회
165330 [질문] 몇일도 표준어가 되는 날이 올까요? [9] 지금이대로4336 22/08/08 4336
165329 [질문] 전세 만기 전 이사 중개수수료 관련 질문 드립니다. [3] cherish4326 22/08/08 4326
165328 [질문] 방에 인터넷 랜선을 연결하고 싶습니다. [8] 맥주귀신6015 22/08/08 6015
165327 [질문] DSR/원리금 균당상환을 예외로 두는 주택/건물 담보 대출? [2] 난할수있다4292 22/08/08 4292
165326 [질문] 트위터에서 리트윗 없이 보기 가능한가요? [12] 던져진12458 22/08/08 12458
165325 [질문] 요즘 집들은 발코니 (베란다 테라스 ...) 가 안방에 있을까요? [7] 로즈마리5587 22/08/08 5587
165324 [질문] 콘서트 티켓은 주운 사람이 임자라는데 맞나요? [16] 앗흥9480 22/08/08 9480
165322 [질문] 서울에 비오면 가기좋은 카페??? [5] 회전목마7147 22/08/08 7147
165321 [질문] 크롬에서 pgr접속시 [2] 살좀빼자6497 22/08/08 6497
165320 [질문] 스팀 에러 118 [3] 동굴곰5401 22/08/08 5401
165319 [질문] 내집마련 이후의 재테크 트리는 뭘까요? [10] 보리차6317 22/08/08 6317
165318 [질문] 주차 후 바퀴를 풀로 돌려놓는 경우 [17] 허느6726 22/08/08 6726
165317 [질문] 전선 설계를 어떻게 하는게 좋을까요? [2] 카오루7124 22/08/08 7124
165316 [질문] 워3 명경기 추천 부탁 드립니다. [2] 손연재5203 22/08/08 5203
165315 [질문] 육아 정보는 어디서 알아보는게 최고일까요? [19] 신류진6987 22/08/08 6987
165314 [질문] 안쓰는 카드는 잘라버리면 되나요? [2] 아이시스 8.04368 22/08/08 4368
165313 [질문] 알펜시아 리조트 근처에 별보러 갈만한 곳 있을까요? [2] EpicSide3919 22/08/08 3919
165312 [질문] 부산 여행 처음가보면 가볼만한데라든가 해볼만한게 있을까요? [6] 레너블7457 22/08/08 7457
165311 [질문] 최근 들을 만한 힙합 추천 부탁드립니다. [5] 40살백수7243 22/08/08 7243
165310 [질문] 폴드3사용하는데 아이콘질문좀 드립니다 [6] 의문의남자4663 22/08/07 4663
165309 [질문] 옛날 주식 / 채권 질문 드립니다. [10] 회색사과10119 22/08/07 10119
165308 [질문] 지속적인 무릎 뒤 통증(근육통) 해결 방법이 있을까요? [4] 10KG빼기4186 22/08/07 4186
165307 [삭제예정] 친구 여행모임 비용처리 관련 질문(저만 불참) [11] 李昇玗8655 22/08/07 8655
목록 이전 다음
댓글

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