>  기사  >  웹 프론트엔드  >  Vue3의 전환 컴포넌트: 컴포넌트 전환 효과 실현

Vue3의 전환 컴포넌트: 컴포넌트 전환 효과 실현

PHPz
PHPz원래의
2023-06-18 08:31:392204검색

Vue3의 전환 구성 요소: 구성 요소 전환 효과 구현

Vue3은 최근 출시된 새로운 버전으로 성능과 개발 경험이 많이 향상되었습니다. 동시에 Vue3는 더 많은 기능을 제공하며 중요한 기능 중 하나는 전환 구성 요소입니다. Vue3에서는 전환 컴포넌트를 사용하여 컴포넌트의 전환 효과를 구현함으로써 UI를 더욱 풍부하고 생생하게 만들 수 있습니다.

전환 구성요소가 무엇인가요?

Vue3에서 전환 구성 요소는 구성 요소에 전환 효과를 추가하는 데 사용할 수 있는 매우 유용한 구성 요소입니다. 일반인의 관점에서 말하면 구성 요소가 나타나고 사라질 때 애니메이션 효과가 있습니다. 이 애니메이션 효과는 페이드 인 및 페이드 아웃, 확대 및 축소 등이 가능하므로 매우 실용적입니다.

전환 구성요소를 사용하여 전환 효과 달성

전환 구성요소를 사용하여 구성요소 전환 효과를 달성하려면 먼저 몇 가지 기본 지식 포인트를 숙지해야 합니다. 첫 번째는 전환 구성 요소의 기본 사용법입니다. 다음은 기본 사용법에 대한 코드 예시입니다.

<template>
    <transition name="fade">
        <div v-if="show">我是一个div组件</div>
    </transition>
    
    <button @click="toggleShow">切换组件</button>
</template>

<script>
export default {
    data() {
        return {
            show: true
        };
    },
    
    methods: {
        toggleShow() {
            this.show = !this.show;
        }
    }
}
</script>

<style>
.fade-enter-active,
.fade-leave-active {
    transition: opacity .5s;
}
.fade-enter,
.fade-leave-to{
    opacity:0;
}
</style>

위 코드에서는 먼저 전환 구성 요소를 정의한 다음 전환 구성 요소에 div 구성 요소를 정의합니다. 이 div 구성 요소는 show가 true인 경우에만 표시됩니다. 다음은 코드에 대한 설명입니다.

  • 는 전환 태그에 "fade"라는 속성을 정의합니다. 이 속성은 애니메이션 프로세스 중에 "fade-" 접두사가 CSS 클래스 이름에 추가됨을 나타냅니다. CSS 클래스 이름에 대한 자세한 설명은 나중에 설명하겠습니다.
  • v-if에서 show의 가치를 판단하세요. true이면 표시되고, false이면 숨겨집니다.
  • 스타일에서는 "fade-enter", "fade-leave-to", "fade-enter-active" 및 "fade-leave-active"라는 클래스를 정의했습니다. 이러한 클래스 이름은 속성에 정의한 "fade"라는 이름과 접두사로 구성됩니다.
  • 컴포넌트가 숨김에서 표시로 변경되면 Vue는 클래스 이름 "fade-enter"를 자동으로 컴포넌트에 추가합니다. 이때 CSS를 통해 컴포넌트의 초기 상태를 설정할 수 있습니다. 마찬가지로, 컴포넌트가 표시됨에서 숨김으로 변경되면 Vue는 자동으로 클래스 이름 "fade-leave-to"를 컴포넌트에 추가합니다. 이때 CSS를 통해 컴포넌트의 최종 상태를 설정할 수 있습니다.
  • 애니메이션 지속 시간을 나타내는 "fade-enter-active" 및 "fade-leave-active"에 CSS 전환 속성을 설정합니다. 여기서는 0.5초로 설정했습니다.
  • 위 단계를 통해 div 구성 요소에 페이드 전환 효과를 성공적으로 추가했습니다.

전환 구성 요소의 CSS 클래스 이름

위 코드에서는 클래스 이름 "fade-enter", "fade-leave-to", "fade-enter-active" 및 "fade-leave-active"를 사용했습니다. ". 이러한 클래스 이름은 전환 구성 요소에 내장되어 있지만 전환의 이름 속성에 따라 접두사를 설정해야 합니다. Vue가 요소의 시작 또는 종료를 감지하면 다음 클래스 이름을 차례로 추가합니다:

  • [name]-enter: 항목의 시작 상태. 이 클래스 이름은 DOM에 추가되는 즉시 요소에 추가됩니다.
  • [이름]-enter-active: 전환 상태에 들어갑니다. 이 클래스 이름은 상태에 들어간 직후 요소에 추가됩니다.
  • [이름]-enter-to: 참가 종료 상태입니다. 이 클래스 이름은 항목 상태가 끝날 때 요소에 추가됩니다.
  • [이름]-leave: 떠나기 시작 상태입니다. 이 클래스 이름은 DOM을 떠나자마자 요소에 추가됩니다.
  • [name]-leave-active: 전환 상태를 종료합니다. 이 클래스 이름은 종료 상태가 끝난 직후 요소에 추가됩니다.
  • [name]-leave-to: 떠나는 종료 상태입니다. 이 클래스 이름은 탈퇴 상태가 끝날 때 요소에 추가됩니다.

이러한 클래스 이름을 기반으로 구성 요소에 대한 전환 효과의 초기, 중간 및 최종 상태를 정의할 수 있습니다.

요약

Vue3에서 전환 구성 요소는 구성 요소 전환 효과를 달성하는 데 사용되는 기본 구성 요소로 구성 요소에 풍부한 시각적 효과를 추가하여 사용자의 대화형 경험을 향상시킬 수 있습니다. 트랜지션 컴포넌트를 사용할 때, 먼저 기본적인 사용법과 관련 CSS 클래스명을 숙지해야 실제 프로젝트에서 활용할 수 있습니다.

위 내용은 Vue3의 전환 컴포넌트: 컴포넌트 전환 효과 실현의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.