웹 프론트엔드 JS 튜토리얼 vue-route를 사용하여 왼쪽 및 오른쪽 페이지 넘김 전환 애니메이션을 자동으로 결정하는 방법

vue-route를 사용하여 왼쪽 및 오른쪽 페이지 넘김 전환 애니메이션을 자동으로 결정하는 방법

Oct 12, 2017 am 10:05 AM
판단 오토매틱

 얼마전에 모바일 스파 프로젝트를 만들었습니다. 기술은 vue + vue-router + vuex + mint-ui

vue-cli 스캐폴딩의 webpack 템플릿을 사용하기 때문에 모든 페이지에서는 .vue 파일을 사용합니다.

최근 회사에서는 상대적으로 적은 수의 프로젝트를 진행하여 마침내 vue-router를 사용한 나의 작은 경험을 기록할 시간을 갖게 되었습니다.

일반 모바일 포트 단일 페이지 애플리케이션에는 페이지로 이동할 때 해당 전환 애니메이션이 있습니다. , 예:

  1. 현재 1단계 페이지에서 2단계 페이지로 점프할 때 표시해야 할 전환 애니메이션은 1단계 페이지가 화면 왼쪽으로 이동하여 사라질 때입니다. ,

   2단계 페이지가 화면 오른쪽에서 왼쪽으로 이동하면서 나타납니다. (책을 다음 페이지로 넘기는 효과와 유사)

  2. 현재 2단계 페이지에서 1단계 페이지로 되돌아갈 때 표시해야 할 전환 애니메이션은 2단계 페이지로 넘어갈 때입니다. 페이지가 화면 오른쪽으로 이동했다가 사라지고,

화면 왼쪽에서 오른쪽으로 이동하면서 1단계 페이지가 나타납니다. (책을 이전 페이지로 되돌리는 효과)

와 유사하지만 질문이 생깁니다. 현재 페이지와 이동할 페이지 간의 계층적 관계를 어떻게 결정합니까?

제가 해결한 방법은 페이지(컴포넌트)를 생성할 때 정의 페이지의 router에 페이지의 path(액세스 경로) 속성을 설정하여 컴포넌트 간의 계층 관계를 구분하는 것입니다.

예를 들어 1단계 페이지(컴포넌트) 'A'의 액세스 경로는 '/A' 입니다. 그의 보조 페이지 'B' 의 액세스 경로는 '/A/B' .

입니다. 그런 다음 해당 페이지로 이동하기 전에 현재 페이지와 이동할 페이지의 경로 깊이만 비교하면 됩니다. 동적으로 전환 애니메이션을 설정합니다.

예를 들어, 깊이가 '/A/B' > '/A' 인 경우 B 페이지에서 A 페이지로 점프하는 것은 효과 2: (회전 책을 이전 페이지로 되돌립니다).

One. 먼저 상위 페이지

home.vue:


 
  
 scoped
로그인 후 복사
.child-view {
 position: absolute;
 width: 100%;
 height: 100%;
 transition: all .5s ease;
 -webkit-transition: all .5s ease;
 -moz-transition: all .5s ease;
}
로그인 후 복사
<em><em><em>.rightin-enter,<br/>.leftin-leave-active {<br/> opacity: 0;<br/> transform: translate3d(50% 0, 0);<br/> -webkit-transform: translate3d(50%, 0, 0);<br/> -moz-transform: translate3d(50%, 0, 0);<br/>}<br/><br/>.leftin-enter,<br/>.rightin-leave-active {<br/> opacity: 0;<br/> transform: translate3d(-50% 0, 0);<br/> -webkit-transform: translate3d(-50%, 0, 0);<br/> -moz-transform: translate3d(-50%, 0, 0);<br/>}<br/><br/><span style="color: #0000ff;"></style></span></em></em></em>
로그인 후 복사

two. 둘째, main.js 조각을 첨부합니다(페이지로 이동하기 전에 전환 애니메이션을 동적으로 설정하는 데 사용됨)

  main.js:


//进入路由之前设置拦截器let noLoginList = ["login", "register", "forget", "home", "classify", "goodsDetial"];
router.routeInfo.beforeEach((to, from, next) => {
  let user = sessionStorage.getItem(&#39;user&#39;);  //如果要去登录页面
  if (noLoginList.indexOf(to.name) >= 0) {    if (!user || user == &#39;&#39;) {      //未登录的状态通行      next();      return;
    } else {      if (["login", "register", "forget"].indexOf(to.name) >= 0) {        //已登录的状态去首页        next({
          name: &#39;home&#39;
        });        return;
      } else {        //已登录的状态去首页        
      next();        
      return;
      }
    }
  } else {    //去登录页面以外的页面(以下是本文关键代码)
    if (user && user != &#39;&#39;) {      //判断是否为需要缓存组件,如果是添加组件名到数组
      if (to.meta.keepAlive) {
        const toName = to.name;
        let keepLi = store.getters.getKeepAlList;
        keepLi.indexOf(toName) < 0 ? keepLi.push(toName) : &#39;&#39;;
        store.commit(&#39;SET_KEEPALLIST&#39;, keepLi);
      }      //根据路径名深度设置转场动画类型
      store.commit(&#39;SET_TRANSNA&#39;, (to.path.split(&#39;/&#39;).length < from.path.split(&#39;/&#39;).length ? &#39;leftin&#39; : &#39;rightin&#39;));
      next();
    } else {
      let toWhere = router.nameList.indexOf(to.name) >= 0 ? to : {name: &#39;home&#39;};
      next({
        name: &#39;login&#39;,
        params: {
          jumpTo: {
            name: toWhere.name,
            params: toWhere.params,
            query: toWhere.query,
          },
        }
      });
    }
  }
});
로그인 후 복사

위 내용은 vue-route를 사용하여 왼쪽 및 오른쪽 페이지 넘김 전환 애니메이션을 자동으로 결정하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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

핫 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 옷 제거제

Video Face Swap

Video Face Swap

완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

PHP 이메일 감지: 이메일이 성공적으로 전송되었는지 확인합니다. PHP 이메일 감지: 이메일이 성공적으로 전송되었는지 확인합니다. Sep 19, 2023 am 09:16 AM

PHP 이메일 감지: 이메일이 성공적으로 전송되었는지 확인합니다. 웹 애플리케이션을 개발할 때 사용자와 통신하기 위해 이메일을 보내야 하는 경우가 종종 있습니다. 등록 확인, 비밀번호 재설정, 알림 전송 등 이메일 기능은 필수적인 부분입니다. 하지만 이메일이 실제로 성공적으로 전송되었는지 확인할 수 없는 경우가 있으므로 이메일 감지를 수행하여 이메일이 성공적으로 전송되었는지 확인해야 합니다. 이 기사에서는 PHP를 사용하여 이 기능을 구현하는 방법을 소개합니다. 1. 이메일을 보내려면 SMTP 서버를 사용하세요. 먼저 SM을 사용해야 합니다.

java의 Character.isDigit() 함수를 사용하여 문자가 숫자인지 확인합니다. java의 Character.isDigit() 함수를 사용하여 문자가 숫자인지 확인합니다. Jul 27, 2023 am 09:32 AM

Java의 Character.isDigit() 함수를 사용하여 문자가 숫자인지 확인합니다. 문자는 컴퓨터 내부에서 ASCII 코드 형식으로 표시됩니다. 그 중 숫자 0~9에 해당하는 아스키코드 값은 각각 48~57이다. 문자가 숫자인지 확인하려면 Java의 Character 클래스에서 제공하는 isDigit() 메서드를 사용할 수 있습니다. isDigit() 메소드는 Character 클래스에 속합니다.

Jul 24, 2023 pm 06:57 PM

Java의 File.isDirectory() 함수를 사용하여 파일이 존재하는지, 디렉토리 유형인지 확인합니다. Java 프로그래밍에서는 파일이 존재하는지, 디렉토리 유형인지 확인해야 하는 상황에 자주 직면합니다. Java는 파일과 디렉터리를 작동하는 File 클래스를 제공합니다. isDirectory() 함수는 파일이 디렉터리 유형인지 확인하는 데 도움이 됩니다. File.isDirectory() 함수는 File 클래스의 메서드입니다. 해당 함수는 현재 File을 결정하는 것입니다.

Linux 팁: vim에 붙여넣을 때 자동 들여쓰기 취소 Linux 팁: vim에 붙여넣을 때 자동 들여쓰기 취소 Mar 07, 2024 am 08:30 AM

서문: vim은 Linux에서 큰 인기를 얻은 강력한 텍스트 편집 도구입니다. 최근에 다른 서버에서 vim을 사용할 때 이상한 문제에 직면했습니다. 로컬로 작성된 스크립트를 복사하여 서버의 빈 파일에 붙여넣을 때 자동 들여쓰기가 발생했습니다. 간단한 예를 사용하기 위해 로컬에서 작성한 스크립트는 다음과 같습니다: aaabbbcccddd. 위 내용을 복사하여 서버의 빈 파일에 붙여넣으면 다음과 같은 결과가 나타납니다: aabbbcccddd. 우리. 형식 들여 쓰기. 그러나 이 자동은 약간 지능적이지 않습니다. 여기에 해결책을 기록하세요. 해결 방법: 홈 디렉터리에 .vimrc 구성 파일을 설정합니다.

JavaScript를 사용한 자동 썸네일 생성 JavaScript를 사용한 자동 썸네일 생성 Jun 16, 2023 pm 12:51 PM

인터넷이 발달하면서 사진은 웹페이지에서 없어서는 안 될 부분이 되었습니다. 하지만 이미지 수가 증가함에 따라 이미지 로딩 속도가 매우 중요한 문제가 되었습니다. 이 문제를 해결하기 위해 많은 웹사이트에서는 썸네일을 사용하여 이미지를 표시하지만, 썸네일을 생성하려면 전문적인 이미지 처리 도구를 사용해야 하는데, 이는 일부 비전문가에게는 매우 번거로운 일입니다. 그런 다음 JavaScript를 사용하여 자동 썸네일 생성을 달성하는 것이 좋은 선택이 됩니다. 자바 사용 방법

Double 클래스의 isInfinite() 메서드를 사용하여 숫자가 무한한지 확인하는 방법 Double 클래스의 isInfinite() 메서드를 사용하여 숫자가 무한한지 확인하는 방법 Jul 24, 2023 am 10:10 AM

Double 클래스의 isInfinite() 메서드를 사용하여 숫자가 무한대인지 확인하는 방법 Java에서 Double 클래스는 부동 소수점 숫자를 나타내는 데 사용되는 래퍼 클래스입니다. 이 클래스는 부동 소수점 숫자에 대해 편리하게 작동할 수 있는 일련의 메서드를 제공합니다. 그 중 isInfinite() 메소드는 부동 소수점 수가 무한한지 여부를 판별하는 데 사용됩니다. 무한대는 부동 소수점 숫자가 나타낼 수 있는 범위를 초과할 정도로 큰 양의 무한대와 음의 무한대를 나타냅니다. 컴퓨터에서는 Double 클래스를 통해 부동 소수점 수의 최대값을 얻을 수 있습니다.

Linux에서 드라이브 자동 마운트 Linux에서 드라이브 자동 마운트 Mar 20, 2024 am 11:30 AM

Linux 운영 체제를 사용하고 시스템이 부팅 시 드라이브를 자동으로 마운트하도록 하려면 장치의 고유 식별자(UID)와 마운트 지점 경로를 fstab 구성 파일에 추가하면 됩니다. fstab은 /etc 디렉터리에 있는 파일 시스템 테이블 파일입니다. 여기에는 시스템 시작 시 마운트해야 하는 파일 시스템에 대한 정보가 포함되어 있습니다. fstab 파일을 편집하면 시스템이 시작될 때마다 필요한 드라이브가 올바르게 로드되어 안정적인 시스템 작동을 보장할 수 있습니다. 드라이버 자동 장착을 통해 다양한 상황에서 편리하게 사용할 수 있습니다. 예를 들어, 내 시스템을 외부 저장 장치에 백업할 계획입니다. 자동화를 달성하려면 시작 시에도 장치가 시스템에 연결된 상태를 유지해야 합니다. 마찬가지로, 많은 애플리케이션이 직접적으로

PHP 및 PHPMAILER: 메일 전송 자동 필터링을 구현하는 방법은 무엇입니까? PHP 및 PHPMAILER: 메일 전송 자동 필터링을 구현하는 방법은 무엇입니까? Jul 21, 2023 am 09:25 AM

PHP 및 PHPMAILER: 메일 전송 자동 필터링을 구현하는 방법은 무엇입니까? 현대사회에서 이메일은 사람들이 소통하는 중요한 수단 중 하나가 되었습니다. 그러나 이메일의 대중화와 확산으로 인해 스팸의 양도 폭발적으로 증가하는 추세를 보이고 있습니다. 스팸 이메일은 사용자의 시간과 네트워크 리소스를 낭비할 뿐만 아니라 바이러스 및 피싱 행위를 가져올 수도 있습니다. 따라서 이메일 발송 기능을 개발할 때 스팸 자동 필터링 기능을 추가하는 것이 중요해집니다. 이 기사에서는 PHP와 PHPMai를 사용하는 방법을 소개합니다.

See all articles