웹 프론트엔드 H5 튜토리얼 H5 단일 페이지 제스처 슬라이딩 화면 전환 원리

H5 단일 페이지 제스처 슬라이딩 화면 전환 원리

Apr 09, 2017 am 09:57 AM
h5 단일 페이지

H5 단일 페이지 제스처 슬라이딩 화면 전환은 HTML5 터치 이벤트(Touch)와 CSS3 애니메이션(Transform, Transition)을 사용하여 구현됩니다. 이 기사에서는 구현 원리와 주요 아이디어에 대해 간략하게 설명합니다.

1. 시행원칙

5개의 페이지가 있고 각 페이지가 화면 너비의 100%를 차지한다고 가정하고 p 컨테이너 뷰포트를 만들고 너비(너비)를 500%로 설정한 다음 5페이지를 컨테이너에 로드하고 5페이지를 균등하게 전체 컨테이너에 대해 나눕니다. , 마지막으로 컨테이너의 기본 위치를 0으로 설정하고 오버플로를 숨김으로 설정하여 기본적으로 화면에 첫 번째 페이지가 표시되도록 합니다.

아아아아

CSS 스타일:

아아아아

touchstart, touchmove 및 touchend 이벤트를 등록하세요. 손가락이 화면에서 미끄러질 때 CSS3 변환을 사용하여 실시간으로 뷰포트의 위치를 ​​설정하세요. 예를 들어 두 번째 페이지를 표시하려면 뷰포트의 변환을 번역3d(100%,0)으로 설정하세요. ,0) 그게 다입니다. 여기서는translateX 대신에translate3d를 사용합니다.translate3d는 휴대폰의 GPU를 적극적으로 켜서 렌더링을 가속화하여 페이지 슬라이드를 더 부드럽게 만듭니다.

2. 주요 아이디어

화면에 손가락을 대고 손가락을 밀고 화면을 떠나면 해당 작업이 다음 이벤트를 트리거합니다.

화면에 손가락을 대세요: ontouchstart

화면 위에서 손가락 슬라이딩: ontouchmove

손가락이 화면에서 나감: ontouchend

페이지 슬라이딩을 완료하려면 터치 이벤트의 세 단계를 캡처해야 합니다.

ontouchstart: 변수 초기화, 손가락 위치 기록, 현재 시간 기록

<p id="viewport" class="viewport">
    <p class="pageview" style="background: #3b76c0" >
        <h3 >页面-1</h3>
    </p>
    <p class="pageview" style="background: #58c03b;">
        <h3>页面-2</h3>
    </p>
    <p class="pageview" style="background: #c03b25;">
        <h3>页面-3</h3>
    </p>
    <p class="pageview" style="background: #e0a718;">
        <h3>页面-4</h3>
    </p>
    <p class="pageview" style="background: #c03eac;">
        <h3>页面-5</h3>
    </p>
</p>
로그인 후 복사

ontouchmove: 현재 위치를 가져오고 화면에서 손가락의 움직임 차이 deltaX를 계산한 다음 페이지가 움직임을 따르도록 만듭니다

.viewport{
   width: 500%;
   height: 100%;
   display: -webkit-box;
   overflow: hidden;
   //pointer-events: none; //这句话会导致整个页面上的点击事件失效,如需绑定点击事件,请注掉
   -webkit-transform: translate3d(0,0,0);
   backface-visibility: hidden;
   position: relative;
}
로그인 후 복사

ontouchend: 손가락이 화면을 떠날 때 화면이 끝나는 페이지를 계산합니다. 먼저 화면에서 손가락의 체류 시간 deltaT를 계산합니다. deltaT<300ms이면 빠른 슬라이드로 간주되고, 그렇지 않으면 빠른 슬라이드와 느린 슬라이드의 처리가 다릅니다.

(1) 퀵 슬라이드인 경우 현재 페이지가 화면 중앙에 완전히 위치하도록 합니다. (현재 페이지에서 얼마나 슬라이드해야 하는지 계산 필요)

(2) 슬라이딩이 느린 경우 손가락이 화면에서 슬라이딩하는 거리도 판단해야 합니다. 슬라이딩 거리가 화면 너비의 50%를 초과하지 않으면 이전 페이지로 돌아가야 합니다. 현재 페이지에 있어야 합니다

/*手指放在屏幕上*/
document.addEventListener("touchstart",function(e){
   e.preventDefault();
   var touch = e.touches[0];
   startX = touch.pageX;
   startY = touch.pageY;
   initialPos = currentPosition;   //本次滑动前的初始位置
   viewport.style.webkitTransition = ""; //取消动画效果
   startT = new Date().getTime(); //记录手指按下的开始时间
   isMove = false; //是否产生滑动
}.bind(this),false);
로그인 후 복사

또한 현재 페이지가 몇 페이지인지 계산하고 현재 페이지 번호를 설정하는 것도 필요합니다

/*手指在屏幕上滑动,页面跟随手指移动*/
document.addEventListener("touchmove",function(e){
   e.preventDefault();
   var touch = e.touches[0];
   var deltaX = touch.pageX - startX;
   var deltaY = touch.pageY - startY;
   //如果X方向上的位移大于Y方向,则认为是左右滑动
   if (Math.abs(deltaX) > Math.abs(deltaY)){
       moveLength = deltaX;
       var translate = initialPos + deltaX; //当前需要移动到的位置
       //如果translate>0 或 < maxWidth,则表示页面超出边界
       if (translate <=0 && translate >= maxWidth){
           //移动页面
           this.transform.call(viewport,translate);
           isMove = true;
       }
       direction = deltaX>0?"right":"left"; //判断手指滑动的方向
   }
}.bind(this),false);

물론, 실제 작업 중에 주의해야 할 몇 가지 세부 사항은 있지만 여기서는 자세히 설명하지 않겠습니다. 소스 코드는 Git에 그대로 반영되어 있습니다. https://github.com/git -onepixel/guesture, 관심있는 학생들의 토론을 환영합니다

위 내용은 H5 단일 페이지 제스처 슬라이딩 화면 전환 원리의 상세 내용입니다. 자세한 내용은 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 옷 제거제

AI Hentai Generator

AI Hentai Generator

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

인기 기사

R.E.P.O. 에너지 결정과 그들이하는 일 (노란색 크리스탈)
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 최고의 그래픽 설정
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 아무도들을 수없는 경우 오디오를 수정하는 방법
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

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

SublimeText3 중국어 버전

SublimeText3 중국어 버전

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

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

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

Golang을 사용하여 단일 페이지 웹 애플리케이션을 개발하는 방법 Golang을 사용하여 단일 페이지 웹 애플리케이션을 개발하는 방법 Jun 05, 2023 am 09:51 AM

인터넷의 지속적인 발전에 따라 웹 애플리케이션에 대한 수요도 증가하고 있습니다. 과거에는 웹 애플리케이션이 여러 페이지로 구성되는 것이 일반적이었지만 이제는 단일 페이지 애플리케이션(SPA)을 사용하는 애플리케이션이 점점 더 많아지고 있습니다. 단일 페이지 애플리케이션은 모바일 액세스에 매우 적합하며 사용자는 전체 페이지가 다시 로드될 때까지 기다릴 필요가 없으므로 사용자 경험이 향상됩니다. 이번 글에서는 Golang을 사용하여 SPA 애플리케이션을 개발하는 방법을 소개하겠습니다. 단일 페이지 애플리케이션이란 무엇입니까? 단일 페이지 애플리케이션은 HTML 파일이 하나만 있는 웹 애플리케이션을 나타냅니다. Jav를 사용합니다.

h5은 무슨 뜻인가요? h5은 무슨 뜻인가요? Aug 02, 2023 pm 01:52 PM

H5는 HTML의 최신 버전인 HTML5를 말하며, H5 기술과 마찬가지로 개발자에게 더 많은 선택권과 창의적인 공간을 제공하는 강력한 마크업 언어입니다. 점차 성숙해지고 대중화되면서 인터넷 세계에서 점점 더 중요한 역할을 담당하게 될 것이라고 믿습니다.

H5, WEB 프론트엔드, 빅 프론트엔드, WEB 풀스택을 어떻게 구별하나요? H5, WEB 프론트엔드, 빅 프론트엔드, WEB 풀스택을 어떻게 구별하나요? Aug 03, 2022 pm 04:00 PM

이 글은 H5, WEB 프론트엔드, 대형 프론트엔드, WEB 풀스택을 빠르게 구별하는 데 도움이 될 것입니다. 도움이 필요한 친구들에게 도움이 되길 바랍니다!

h5에서 위치를 사용하는 방법 h5에서 위치를 사용하는 방법 Dec 26, 2023 pm 01:39 PM

H5에서는 position 속성을 사용하여 CSS를 통해 요소의 위치 지정을 제어할 수 있습니다. 1. 상대 위치 지정, 구문은 "style="position:relative;"; 2. 절대 위치 지정, 구문은 "style="position: 절대;" "; 3. 고정 위치 지정, 구문은 "style="position:fixed;" 등입니다.

다음 페이지를 로드하기 위해 웹 측에서 위로 슬라이드되도록 h5를 구현하는 방법 다음 페이지를 로드하기 위해 웹 측에서 위로 슬라이드되도록 h5를 구현하는 방법 Mar 11, 2024 am 10:26 AM

구현 단계: 1. 페이지의 스크롤 이벤트를 모니터링합니다. 2. 페이지가 아래쪽으로 스크롤되었는지 확인합니다. 3. 데이터의 다음 페이지를 로드합니다. 4. 페이지 스크롤 위치를 업데이트합니다.

vue3에서 H5 양식 유효성 검사 구성 요소를 구현하는 방법 vue3에서 H5 양식 유효성 검사 구성 요소를 구현하는 방법 Jun 03, 2023 pm 02:09 PM

렌더링 설명은 vue.js를 기반으로 하며 다른 플러그인이나 라이브러리에 의존하지 않습니다. 기본 기능은 element-ui와 일관되게 유지되며 모바일 차이점을 위해 내부 구현에 일부 조정이 이루어졌습니다. 현재 구축 플랫폼은 uni-app 공식 스캐폴딩을 사용하여 구축되었습니다. 현재 대부분의 모바일 단말기에는 h6 및 WeChat 미니 프로그램의 두 가지 유형이 있으므로 여러 단말기에서 하나의 코드 세트를 실행하는 기술 선택에 매우 적합합니다. 구현 아이디어 핵심 API: 및에 해당하는 제공 및 주입을 사용합니다. 컴포넌트에서는 내부적으로 변수(배열)를 사용하여 모든 인스턴스를 저장하고, 전송될 데이터는 제공을 통해 노출됩니다. 컴포넌트는 내부적으로 주입을 사용하여 상위 컴포넌트에서 제공하는 데이터를 수신하고 최종적으로 자신의 속성을 방법 제출

새로운 H5 프로모션 태그 요약 및 소개(예제 포함) 새로운 H5 프로모션 태그 요약 및 소개(예제 포함) Aug 03, 2022 pm 05:10 PM

​이 글에서는 새로운 H5 프로모션 태그에 대해 소개하겠습니다. 도움이 필요한 친구들에게 도움이 되길 바랍니다!

페이지 h5와 PHP는 무엇을 의미합니까? (관련 지식 토론) 페이지 h5와 PHP는 무엇을 의미합니까? (관련 지식 토론) Mar 20, 2023 pm 02:23 PM

HTML5와 PHP는 웹 개발에 일반적으로 사용되는 두 가지 기술입니다. 전자는 페이지 레이아웃, 스타일 및 상호 작용을 구축하는 데 사용되며 후자는 서버 측 비즈니스 논리 및 데이터 저장을 처리하는 데 사용됩니다. HTML5와 PHP에 대한 관련 지식을 살펴보겠습니다.

See all articles