> 웹 프론트엔드 > View.js > Vue Router에서 라우팅 전환 애니메이션은 어떻게 구현됩니까?

Vue Router에서 라우팅 전환 애니메이션은 어떻게 구현됩니까?

PHPz
풀어 주다: 2023-07-23 16:13:56
원래의
1611명이 탐색했습니다.

Vue Router에서는 라우팅 전환 애니메이션이 어떻게 구현되나요?

Vue Router는 Vue.js에서 공식적으로 제공하는 라우팅 관리 플러그인으로, 페이지의 경로를 쉽게 구성하고 관리할 수 있으며, 라우팅 전환 애니메이션과 같은 사용자 경험을 향상시키는 몇 가지 기능도 제공합니다. 이러한 애니메이션 효과를 통해 페이지 전환이 더욱 부드럽고 원활해지며 사용자에게 더 나은 시각 효과와 상호 작용 경험을 제공합니다. 그렇다면 Vue Router의 경로 전환 애니메이션은 어떻게 구현됩니까? 이에 대해서는 아래에서 자세히 논의해 보겠습니다.

먼저 Vue 라우터 플러그인을 설치하고 Vue 인스턴스에 도입해야 합니다.

import Vue from 'vue'
import VueRouter from 'vue-router'

Vue.use(VueRouter)
로그인 후 복사

다음으로 라우팅 구성에서 페이지를 전환할 때 전환 애니메이션을 정의해야 합니다. Vue Router는 전환 애니메이션의 트리거 타이밍, 즉 beforeEnterleave를 제어하는 ​​두 가지 후크 기능을 제공합니다. 라우팅 구성의 각 라우팅 개체에 이 두 가지 후크 기능을 설정하여 들어오고 나갈 때 애니메이션 효과를 제어할 수 있습니다. beforeEnterleave。我们可以在路由配置的每个路由对象中设置这两个钩子函数,来控制进入和离开时的动画效果。

首先,我们来定义页面进入时的过渡动画。在路由配置中,如果希望给某个路由对象设置进入动画,可以在该路由对象中添加beforeEnter钩子函数,并在其中使用Vue的过渡动画模块<transition>来定义动画效果。例如:

const routes = [
  {
    path: '/',
    name: 'Home',
    component: Home,
    // 定义进入动画
    beforeEnter: (to, from, next) => {
      next(vm => {
        const el = vm.$el.getElementsByClassName('app')[0]
        el.style.transform = 'translate(0, 100%)'
        el.style.opacity = '0'
        setTimeout(() => {
          el.style.transition = 'transform 0.3s, opacity 0.3s'
          el.style.transform = 'translate(0, 0)'
          el.style.opacity = '1'
        }, 0)
      })
    }
  },
  // ...
]
로그인 후 복사

在上述代码中,我们将beforeEnter钩子函数中的next函数中传入的回调函数中执行页面进入的动画效果,首先将页面元素的transformopacity属性设置为需要的动画初始状态,然后通过setTimeout函数将动画属性设置为需要的最终状态。

接下来,我们来定义页面离开时的过渡动画。在路由配置中,如果希望给某个路由对象设置离开动画,可以在该路由对象中添加leave钩子函数,并在其中使用Vue的过渡动画模块<transition>来定义动画效果。例如:

const routes = [
  // ...
  {
    path: '/about',
    name: 'About',
    component: About,
    // 定义离开动画
    leave: (to, from, next) => {
      const el = document.getElementsByClassName('app')[0]
      el.style.transition = 'transform 0.3s, opacity 0.3s'
      el.style.transform = 'translate(0, 100%)'
      el.style.opacity = '0'
      setTimeout(next, 300)
    }
  },
  // ...
]
로그인 후 복사

在上述代码中,我们通过在leave钩子函数中将页面元素的transformopacity属性设置为需要的动画最终状态,并通过setTimeout函数延迟300毫秒后执行next

먼저 페이지 진입 시 전환 애니메이션을 정의해 보겠습니다. 라우팅 구성에서 라우팅 객체에 대한 진입 애니메이션을 설정하려면 라우팅 객체에 beforeEnter 후크 기능을 추가하고 Vue의 전환 애니메이션 모듈 <transition> /code> 애니메이션 효과를 정의합니다. 예:

const router = new VueRouter({
  routes
})

const app = new Vue({
  router
}).$mount('#app')
로그인 후 복사
위 코드에서는 beforeEnter 후크 함수의 next 함수에 전달된 콜백 함수에서 페이지 항목의 애니메이션 효과를 실행합니다. , 페이지에서 요소의 transformopacity 속성은 필요한 애니메이션 초기 상태로 설정되고, 그런 다음 애니메이션 속성은 다음을 통해 필요한 최종 상태로 설정됩니다. setTimeout 함수.

다음으로 페이지가 나갈 때 전환 애니메이션을 정의해 보겠습니다. 라우팅 구성에서 라우팅 개체에 대한 나가기 애니메이션을 설정하려면 라우팅 개체에 leave 후크 기능을 추가하고 Vue의 전환 애니메이션 모듈 <transition> /code> 애니메이션 효과를 정의합니다. 예:

rrreee

위 코드에서는 페이지 요소의 transformopacity 속성을 ​​leave의 필수 속성으로 설정했습니다. 후크 함수 애니메이션의 최종 상태이며 setTimeout 함수를 사용하여 next 함수의 실행을 300밀리초 동안 지연하여 나가는 애니메이션의 실행을 제어합니다. 🎜🎜마지막으로 Vue 인스턴스에 Vue Router 인스턴스를 생성하고 라우팅 구성을 전달해야 합니다. 🎜rrreee🎜위 단계를 통해 Vue Router에서 라우팅 전환 애니메이션을 성공적으로 구현했습니다. 페이지를 전환하면 Vue Router는 경로 전환 전환 애니메이션을 자동으로 트리거하여 사용자에게 더 부드럽고 멋진 페이지 전환 효과를 제공합니다. 🎜🎜결론적으로 Vue Router의 Hook 기능과 Vue의 전환 애니메이션 모듈을 사용하면 경로 전환 애니메이션을 쉽게 구현하고 사용자 경험을 향상시킬 수 있습니다. 프로그래머는 자신의 필요와 창의성에 따라 다양한 애니메이션 효과를 사용자 정의하여 페이지를 더욱 생생하고 흥미롭게 만들 수 있습니다. 이 글의 소개가 Vue Router 라우팅 전환 애니메이션에 대한 이해를 심화시키고 실제 개발에 도움이 되기를 바랍니다. 🎜

위 내용은 Vue Router에서 라우팅 전환 애니메이션은 어떻게 구현됩니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿