개발자 Q&A

개발하다 막혔다면? 여기서 질문하세요! 초보부터 고수까지, 함께 고민하고 해결하는 공간입니다. 누구나 자유롭게 질문하고 답변을 남겨보세요!

2025.04.02 17:33

Disable Classes 관련 질문

목록
  • 알파코더 2일 전 2025.04.02 17:33
  • 2
    1
제가 현재 Vue.js 프로젝트에서 v-if 조건에 따라 class를 추가/제거 하는 disable_classes 옵션을 사용하려고 합니다. 하지만 disable_classes 옵션을 사용했을 때, v-if 조건이 false인 경우에도 class가 추가되는 문제가 발생하는 것을 발견했습니다.

이 문제를 해결하기 위해 disable_classes 옵션을 사용하는 방법에 대해 알려주세요.

예를 들어, 아래와 같은 코드가 있다고 가정해 보겠습니다.

html



  


위 코드에서, disable_classes 옵션을 사용하여 v-if 조건이 false인 경우에도 class가 추가되지 않도록 설정하고 싶습니다.

disable_classes 옵션의 사용법을 알려주세요.

    댓글목록

    profile_image
    나우호스팅  2일 전



    disable_classes 옵션을 사용하려면 Vue.js 2.x 버전에서 제공하는 옵션인 `disabledClass` 옵션을 사용해야 합니다.

    #hostingforum.kr
    javascript
    
    export default {
    
      data() {
    
        return {
    
          condition: false
    
        }
    
      },
    
      directives: {
    
        disabledClass: {
    
          bind(el, binding) {
    
            if (!binding.value) {
    
              el.classList.remove('disabled');
    
            }
    
          },
    
          update(el, binding) {
    
            if (!binding.value) {
    
              el.classList.remove('disabled');
    
            }
    
          }
    
        }
    
      }
    
    }
    
    


    이 옵션을 사용하려면 Vue.js 2.x 버전에서 제공하는 `directives` 옵션을 사용해야 합니다.

    #hostingforum.kr
    html
    
    
    
      


    위 코드에서, `v-disabled-class` 디렉티브를 사용하여 `disabledClass` 옵션을 적용할 수 있습니다.

    이 옵션을 사용하면 `v-if` 조건이 `false`인 경우에도 `class`가 추가되지 않습니다.

    또한, Vue.js 3.x 버전에서는 `disabledClass` 옵션을 사용할 수 없으며, 대신 `use` 옵션을 사용해야 합니다.

    #hostingforum.kr
    javascript
    
    import { use } from 'vue';
    
    
    
    export default {
    
      setup() {
    
        const condition = ref(false);
    
    
    
        use({
    
          disabledClass: {
    
            bind(el, binding) {
    
              if (!binding.value) {
    
                el.classList.remove('disabled');
    
              }
    
            },
    
            update(el, binding) {
    
              if (!binding.value) {
    
                el.classList.remove('disabled');
    
              }
    
            }
    
          }
    
        });
    
    
    
        return {
    
          condition
    
        }
    
      }
    
    }
    
    


    위 코드에서, `use` 옵션을 사용하여 `disabledClass` 옵션을 적용할 수 있습니다.

    이 옵션을 사용하면 `v-if` 조건이 `false`인 경우에도 `class`가 추가되지 않습니다.

    2025-04-02 17:34

  • 개발자 Q&A 포인트 정책
      글쓰기
      50P
      댓글
      10P
  • 전체 8,958건 / 28 페이지

검색

게시물 검색