찾다
웹 프론트엔드View.jsVue 페이지 전환 애니메이션 구현 및 일반 애니메이션 효과

Vue 페이지 전환 애니메이션 구현 및 일반 애니메이션 효과

Jun 09, 2023 pm 04:11 PM
vue애니메이션 효과페이지 전환

Vue는 데이터 기반 접근 방식을 사용하여 개발자가 강력한 상호 작용과 아름다운 데이터 표현을 갖춘 단일 페이지 웹 애플리케이션을 구축할 수 있도록 지원하는 인기 있는 JavaScript 프레임워크입니다. Vue에는 유용한 기능이 많이 내장되어 있으며 그 중 하나가 페이지 전환 애니메이션입니다. 이 글에서는 Vue의 전환 애니메이션 기능을 사용하는 방법을 소개하고 가장 일반적인 애니메이션 효과에 대해 논의합니다.

Vue 페이지 전환 애니메이션 구현

Vue의 페이지 전환 애니메이션은 Vue의 <transition></transition><transition-group></transition-group> 구성 요소를 통해 구현됩니다. 아래에서는 이 두 가지 구성 요소를 각각 소개합니다. <transition></transition><transition-group></transition-group>组件实现的。下面我们分别介绍这两个组件。

<transition></transition>

<transition></transition>组件可以在被包裹的元素在插入、更新或者移除时,自动执行过渡动画效果。

该组件向外部发出before-enterenterafter-enterenter-cancelledbefore-leaveleaveafter-leaveleave-cancelled等钩子函数,让我们可以控制过渡的开始、结束和取消。

下面是一个简单的<transition></transition>动画效果,展示了一个元素在插入时的过渡动画。请注意,该组件需要一个name属性,用于指定动画的名称。在下面的例子中,动画名称是fade。这里的CSS样式定义了开始和结束时元素的过渡动画效果。

<template>
  <div>
    <button @click="show = !show">Toggle show</button>
    <transition name="fade">
      <div v-if="show">Hello Vue!</div>
    </transition>
  </div>
</template>

<script>
export default {
  data() {
    return {
      show: true,
    };
  },
};
</script>

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

<transition-group></transition-group>

<transition-group></transition-group>组件与<transition></transition>很相似,但是它适用于列表项或者表格等需要同时进行插入和移除的元素。

<transition></transition>组件一样,在<transition-group></transition-group>组件中可以定义钩子函数,如before-enterenter等。

<transition-group></transition-group>需要指定一个tag属性,用于指定过渡组件生成的HTML标签类型。它还需要每个子元素带有一个唯一的键值,使Vue可以正确地识别插入、更新或者移除的元素。

在下面的例子中,我们展示了一个简单的列表,每当点击按钮时,都会添加或者删除一项。在这个例子中,我们使用了<transition-group></transition-group>组件,并且指定了HTML标签类型为ul。列表中的每个项都带有一个键值,以帮助Vue正确地执行过渡动画。

<template>
  <div>
    <button @click="shift()">Add/Remove Item</button>
    <transition-group name="list" tag="ul">
      <li v-for="item in items" :key="item">{{ item }}</li>
    </transition-group>
  </div>
</template>

<script>
export default {
  data() {
    return {
      items: ["Item 1", "Item 2", "Item 3", "Item 4", "Item 5"],
    };
  },
  methods: {
    shift() {
      if (this.items.length > 0) {
        this.items.shift();
      } else {
        this.items.push("New Item");
      }
    },
  },
};
</script>

<style>
.list-enter-active,
.list-leave-active {
  transition: all 0.5s;
}
.list-enter,
.list-leave-to {
  opacity: 0;
  transform: translateY(30px);
}
</style>

常用的过渡动画效果

现在,我们已经介绍了如何使用Vue的过渡动画。下面让我们来看看一些常见的过渡动画效果。

Fade

Fade效果用于渐隐或者渐显的效果。它将元素的不透明度从0变化到1或者从1变化到0。

<transition name="fade">
  <div v-if="show">Hello Vue!</div>
</transition>

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

Slide

Slide效果用于元素从一侧滑出或者滑动到一侧的效果。它将元素的位置从一个位置移动到另一个位置。

<transition name="slide">
  <div v-if="show">Hello Vue!</div>
</transition>

<style>
.slide-enter-active,
.slide-leave-active {
  transition: transform 0.5s;
}
.slide-enter-to,
.slide-leave {
  transform: translateX(100%);
}
.slide-enter,
.slide-leave-to {
  transform: translateX(-100%);
}
</style>

Scale

Scale效果用于元素从小到大或者从大到小的缩放效果。它将元素的宽度和高度从一种大小缩小到另一种大小。

<template>
  <div>
    <button @click="show = !show">Toggle show</button>
    <transition name="scale">
      <div v-if="show" class="box"></div>
    </transition>
  </div>
</template>

<style>
.box {
  width: 100px;
  height: 100px;
  background-color: red;
}
.scale-enter-active,
.scale-leave-active {
  transition: transform 0.5s;
}
.scale-enter,
.scale-leave-to {
  transform: scale(0);
}
</style>

Rotate

Rotate效果用于元素绕着一个轴旋转的效果。它将元素绕着一个角度旋转。

<template>
  <div>
    <button @click="show = !show">Toggle show</button>
    <transition name="rotate">
      <div v-if="show" class="box"></div>
    </transition>
  </div>
</template>

<style>
.box {
  width: 100px;
  height: 100px;
  background-color: red;
}
.rotate-enter-active,
.rotate-leave-active {
  transition: transform 0.5s;
}
.rotate-enter,
.rotate-leave-to {
  transform: rotate(180deg);
}
</style>

总结

Vue的过渡动画功能可以让我们在页面元素插入、更新或者移除时,添加动画过渡效果,从而使页面更加生动和有趣。本文介绍了如何使用Vue的<transition></transition><transition-group></transition-group>

<transition></transition>

<transition></transition> 구성 요소는 래핑된 요소가 삽입, 업데이트 또는 제거될 때 자동으로 전환 애니메이션 효과를 수행할 수 있습니다. 🎜🎜이 구성 요소는 입력 전, 입력, 입력 후, 입력 취소 및 before-leave, leave, after-leave, leave-cancelled와 같은 코드를 사용하면 전환 시작을 제어할 수 있습니다. 종료하고 취소하세요. 🎜🎜다음은 삽입 시 요소의 전환 애니메이션을 보여주는 간단한 <transition></transition> 애니메이션 효과입니다. 이 구성요소에는 애니메이션 이름을 지정하기 위한 name 속성이 필요합니다. 아래 예에서 애니메이션 이름은 fade입니다. 여기의 CSS 스타일은 시작과 끝에서 요소의 전환 애니메이션 효과를 정의합니다. 🎜rrreee

<transition-group></transition-group>

🎜<transition-group></transition-group> 구성 요소는 <transition></transition>과 매우 유사하지만 다음과 같이 작동합니다. 동시에 삽입하고 제거해야 하는 항목이나 테이블과 같은 요소를 나열합니다. 🎜🎜<transition></transition> 구성 요소와 마찬가지로 before-enter와 같은 <transition-group></transition-group> 구성 요소에서 후크 기능을 정의할 수 있습니다. 코드>, 입력 등. 🎜🎜<transition-group></transition-group>는 전환 구성 요소에서 생성된 HTML 태그 유형을 지정하기 위해 tag 속성을 ​​지정해야 합니다. 또한 Vue가 삽입, 업데이트 또는 제거된 요소를 올바르게 식별할 수 있도록 각 하위 요소에는 고유한 키 값이 있어야 합니다. 🎜🎜아래 예에서는 버튼을 클릭할 때마다 항목을 추가하거나 제거하는 간단한 목록을 보여줍니다. 이 예에서는 <transition-group></transition-group> 구성 요소를 사용하고 HTML 태그 유형을 ul로 지정합니다. 목록의 각 항목에는 Vue가 전환 애니메이션을 올바르게 수행하는 데 도움이 되는 키 값이 함께 제공됩니다. 🎜rrreee🎜일반적으로 사용되는 전환 애니메이션 효과🎜🎜이제 Vue의 전환 애니메이션 사용법을 소개했습니다. 몇 가지 일반적인 전환 애니메이션 효과를 살펴보겠습니다. 🎜

페이드

🎜페이드 효과는 페이드 아웃하거나 페이드 아웃하는 데 사용됩니다. 요소의 불투명도를 0에서 1로 또는 1에서 0으로 변경합니다. 🎜rrreee

슬라이드

🎜슬라이드 효과는 요소가 슬라이드 아웃되거나 한쪽으로 슬라이드되는 데 사용됩니다. 요소의 위치를 ​​한 위치에서 다른 위치로 이동합니다. 🎜rrreee

Scale

🎜Scale 효과는 요소를 작은 것에서 큰 것으로 또는 큰 것에서 작은 것으로 크기를 조정하는 데 사용됩니다. 요소의 너비와 높이를 한 크기에서 다른 크기로 축소합니다. 🎜rrreee

회전

🎜회전 효과는 축을 중심으로 요소를 회전하는 데 사용됩니다. 요소를 각도로 회전시킵니다. 🎜rrreee🎜Summary🎜🎜Vue의 전환 애니메이션 기능을 사용하면 페이지 요소가 삽입, 업데이트 또는 제거될 때 애니메이션 전환 효과를 추가하여 페이지를 더욱 생생하고 흥미롭게 만들 수 있습니다. 이 글에서는 Vue의 <transition></transition><transition-group></transition-group> 구성요소를 사용하여 전환 애니메이션을 구현하는 방법을 소개합니다. 또한 일반적으로 사용되는 몇 가지 전환 애니메이션 효과도 소개합니다. Vue 애플리케이션에 애니메이션 효과를 추가해야 하는 경우 다음 구성 요소를 사용해 볼 수 있습니다. 🎜

위 내용은 Vue 페이지 전환 애니메이션 구현 및 일반 애니메이션 효과의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
프론트 엔드 환경 : 넷플릭스가 선택에 어떻게 접근했는지프론트 엔드 환경 : 넷플릭스가 선택에 어떻게 접근했는지Apr 15, 2025 am 12:13 AM

프론트 엔드 기술에서 Netflix의 선택은 주로 성능 최적화, 확장 성 및 사용자 경험의 세 가지 측면에 중점을 둡니다. 1. 성능 최적화 : Netflix는 React를 주요 프레임 워크로 선택하고 Speedcurve 및 Boomerang과 같은 도구를 개발하여 사용자 경험을 모니터링하고 최적화했습니다. 2. 확장 성 : 마이크로 프론트 엔드 아키텍처를 채택하여 응용 프로그램을 독립 모듈로 분할하여 개발 효율성 및 시스템 확장 성을 향상시킵니다. 3. 사용자 경험 : Netflix는 재료 -UI 구성 요소 라이브러리를 사용하여 A/B 테스트 및 사용자 피드백을 통해 인터페이스를 지속적으로 최적화하여 일관성과 미학을 보장합니다.

React vs. Vue : Netflix는 어떤 프레임 워크를 사용합니까?React vs. Vue : Netflix는 어떤 프레임 워크를 사용합니까?Apr 14, 2025 am 12:19 AM

NetflixusesAcustomFrameworkCalled "Gibbon"BuiltonReact, NotreactorVuedirectly.1) TeamExperience : 2) ProjectComplexity : vueforsimplerProjects, 3) CustomizationNeeds : reactoffersmoreflex.4)

프레임 워크의 선택 : Netflix의 결정을 이끌어내는 것은 무엇입니까?프레임 워크의 선택 : Netflix의 결정을 이끌어내는 것은 무엇입니까?Apr 13, 2025 am 12:05 AM

Netflix는 주로 프레임 워크 선택의 성능, 확장 성, 개발 효율성, 생태계, 기술 부채 및 유지 보수 비용을 고려합니다. 1. 성능 및 확장 성 : Java 및 SpringBoot는 대규모 데이터 및 높은 동시 요청을 효율적으로 처리하기 위해 선택됩니다. 2. 개발 효율성 및 생태계 : React를 사용하여 프론트 엔드 개발 효율성을 향상시키고 풍부한 생태계를 활용하십시오. 3. 기술 부채 및 유지 보수 비용 : Node.js를 선택하여 유지 보수 비용과 기술 부채를 줄이기 위해 마이크로 서비스를 구축하십시오.

Netflix의 프론트 엔드의 반응, vue 및 미래Netflix의 프론트 엔드의 반응, vue 및 미래Apr 12, 2025 am 12:12 AM

Netflix는 주로 VUE가 특정 기능을 위해 보충하는 프론트 엔드 프레임 워크로 React를 사용합니다. 1) React의 구성 요소화 및 가상 DOM은 Netflix 애플리케이션의 성능 및 개발 효율을 향상시킵니다. 2) VUE는 Netflix의 내부 도구 및 소규모 프로젝트에 사용되며 유연성과 사용 편의성이 핵심입니다.

프론트 엔드의 vue.js : 실제 응용 프로그램 및 예제프론트 엔드의 vue.js : 실제 응용 프로그램 및 예제Apr 11, 2025 am 12:12 AM

vue.js는 복잡한 사용자 인터페이스를 구축하는 데 적합한 점진적인 JavaScript 프레임 워크입니다. 1) 핵심 개념에는 반응 형 데이터, 구성 요소화 및 가상 DOM이 포함됩니다. 2) 실제 응용 분야에서는 TODO 응용 프로그램을 구축하고 Vuerouter를 통합하여 시연 할 수 있습니다. 3) 디버깅 할 때 VuedeVtools 및 Console.log를 사용하는 것이 좋습니다. 4) 성능 최적화는 V-IF/V- 쇼, 목록 렌더링 최적화, 구성 요소의 비동기로드 등을 통해 달성 할 수 있습니다.

vue.js and React : 주요 차이점 이해vue.js and React : 주요 차이점 이해Apr 10, 2025 am 09:26 AM

vue.js는 중소형 프로젝트에 적합하지만 REACT는 크고 복잡한 응용 프로그램에 더 적합합니다. 1. Vue.js의 응답 형 시스템은 종속성 추적을 통해 DOM을 자동으로 업데이트하여 데이터 변경을 쉽게 관리 할 수 ​​있습니다. 2. 반응은 단방향 데이터 흐름을 채택하고 데이터 흐름에서 하위 구성 요소로 데이터가 흐르고 명확한 데이터 흐름과 곤란하기 쉬운 구조를 제공합니다.

vue.js vs. React : 프로젝트 별 고려 사항vue.js vs. React : 프로젝트 별 고려 사항Apr 09, 2025 am 12:01 AM

vue.js는 중소형 프로젝트 및 빠른 반복에 적합한 반면 React는 크고 복잡한 응용 프로그램에 적합합니다. 1) vue.js는 사용하기 쉽고 팀이 불충분하거나 프로젝트 규모가 작는 상황에 적합합니다. 2) React는 더 풍부한 생태계를 가지고 있으며 고성능 및 복잡한 기능적 요구가있는 프로젝트에 적합합니다.

태그를 vue로 점프하는 방법태그를 vue로 점프하는 방법Apr 08, 2025 am 09:24 AM

VUE에서 태그의 점프를 구현하는 방법에는 다음이 포함됩니다. HTML 템플릿의 A 태그를 사용하여 HREF 속성을 지정합니다. VUE 라우팅의 라우터 링크 구성 요소를 사용하십시오. javaScript 에서이. $ router.push () 메소드를 사용하십시오. 매개 변수는 쿼리 매개 변수를 통해 전달 될 수 있으며 동적 점프를 위해 라우터 옵션에서 경로가 구성됩니다.

See all articles

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

인기 기사

R.E.P.O. 에너지 결정과 그들이하는 일 (노란색 크리스탈)
4 몇 주 전By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 최고의 그래픽 설정
4 몇 주 전By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 아무도들을 수없는 경우 오디오를 수정하는 방법
4 몇 주 전By尊渡假赌尊渡假赌尊渡假赌
WWE 2K25 : Myrise에서 모든 것을 잠금 해제하는 방법
1 몇 달 전By尊渡假赌尊渡假赌尊渡假赌

뜨거운 도구

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

안전한 시험 브라우저

안전한 시험 브라우저

안전한 시험 브라우저는 온라인 시험을 안전하게 치르기 위한 보안 브라우저 환경입니다. 이 소프트웨어는 모든 컴퓨터를 안전한 워크스테이션으로 바꿔줍니다. 이는 모든 유틸리티에 대한 액세스를 제어하고 학생들이 승인되지 않은 리소스를 사용하는 것을 방지합니다.

SublimeText3 Linux 새 버전

SublimeText3 Linux 새 버전

SublimeText3 Linux 최신 버전

맨티스BT

맨티스BT

Mantis는 제품 결함 추적을 돕기 위해 설계된 배포하기 쉬운 웹 기반 결함 추적 도구입니다. PHP, MySQL 및 웹 서버가 필요합니다. 데모 및 호스팅 서비스를 확인해 보세요.

WebStorm Mac 버전

WebStorm Mac 버전

유용한 JavaScript 개발 도구