>웹 프론트엔드 >JS 튜토리얼 >스크롤 뷰를 사용하여 WeChat 애플릿에서 앵커 슬라이딩을 구현하는 방법

스크롤 뷰를 사용하여 WeChat 애플릿에서 앵커 슬라이딩을 구현하는 방법

亚连
亚连원래의
2018-06-22 14:40:352990검색

이 글은 주로 WeChat 애플릿 스크롤뷰에서 앵커 슬라이딩을 구현한 예를 소개합니다. 편집자가 꽤 좋다고 생각해서 지금 공유하고 참고하겠습니다. 편집자를 따라가서 함께 살펴봅시다

머리말

최근에 작은 프로그램을 만들기 시작했습니다. 문서를 읽고 시작하는 것은 어렵지 않지만 작은 프로그램에는 여전히 몇 가지 함정이 있다고 말씀드리고 싶습니다. . 페이지 앵커 점프를 구현하는 방법에 대해 이야기해 보겠습니다. 도시 목록의 효과에 대한 도식은 다음과 같습니다.

WeChat 애플릿 환경에서는 브라우저에서 태그를 설정하거나 DOM 스크롤을 조작할 수 없습니다. 전통적인 방법은 작동하지 않습니다. 예, 모든 것이 미니 프로그램의 문서에 따라야 합니다.

처음에 우리가 한 일은boundingClientRect() 메서드를 사용하여 각 앵커 포인트의 좌표를 가져온 다음 wx.pageScrollTo() 메서드를 사용하여 슬라이드하는 것이었습니다. 결과적으로는 화면이 슬라이드됨에 따라boundingClientRect 메서드에서 반환된 각 지점의 좌표가 변경되어 결국 페이지가 흔들리게 되므로 효과가 그다지 좋지 않은 것으로 나타났습니다. ) 앵커 포인트 효과를 얻기 위해 구성 요소가 선택되었습니다.

특정 구현

특정 API에 대해서는 자세히 설명하지 않겠습니다. 다음은 주의가 필요한 몇 가지 사항입니다. 속성이 필요합니다:

<scroll-view scroll-y style="height: 200px;" bindscroll="scroll" scroll-into-view="{{toView}}" >

scroll-into-view: 속성에 바인딩됩니다. 해당 값은 페이지 요소의 ID여야 합니다. 해당 값을 설정하면 ID에 해당하는 요소로 이동합니다.

scroll-y: 수직 슬라이딩을 나타내려면 이 속성을 추가하고, 해당 스크롤-x는 수직 슬라이딩을 나타낼 때 고정 높이를 설정해야 합니다.

bindscroll: 슬라이딩을 모니터링하고 이벤트에 전달합니다. 문서에는 많은 속성이 제공되어 있으므로 현재는 위의 몇 가지 속성만 사용하면 원하는 효과를 얻을 수 있습니다. 구현 원리도 매우 간단합니다. 컨텐츠 부분에서는 뷰의 각 영문 약어를 ID로 설정한 후 탐색 목록을 클릭하면 클릭한 ID로 스크롤 인투(Scroll-into-view) 값을 설정하여 구현합니다. 점프.

스크롤 뷰의 높이에 대해 이야기해 보겠습니다. 이는 조정된 고정 높이여야 합니다. 그렇지 않으면 화면 크기가 다른 휴대폰에서 표시 효과가 달라집니다.

몇 가지 최적화

지금까지 기능은 기본적으로 구현되었지만 나중에 몇 가지 문제가 발견되었습니다. 스크롤 보기의 스크롤 막대를 숨기려면 CSS 스타일을 설정해야 합니다.: :-webkit-scrollbar

::-webkit-scrollbar {
 width: 0;
 height: 0;
 color: transparent;
}

또한 점프를 구현하려면 앵커 포인트를 클릭하기만 하면 됩니다. 이때 페이지를 스크롤하고 이전에 클릭한 앵커 포인트를 클릭하면 페이지가 다시 점프하지 않습니다. 스크롤 이벤트를 수신하고 스크롤할 때 스크롤 보기 속성을 설정합니다. 또는 각 앵커 포인트 점프 후에 비동기 작업이 스크롤 보기 속성 값을 지웁니다.

2017/12/05 추가:

scroll-view에는 기본적으로 슬라이딩 애니메이션이 없습니다. 스크롤이 필요한 애니메이션 효과는 구성 요소에서 설정해야 합니다: scroll-with-animation='true'

설정 정보 고정 높이 높이 문제, 처음에는 이 높이가 스크롤 요소의 수/높이와 관련이 있다고 생각했습니다. 이때 동적으로 변경되는 목록을 처리하는 것은 매우 번거로울 것입니다. 나중에 인터넷에서 본 방법은 wx.getSystemInfo 메서드를 사용하여 windowHeight를 가져오고 이를 스크롤 뷰의 높이(단위: px)로 설정하는 것입니다.


위 내용은 모두를 위해 제가 정리한 내용입니다. 앞으로 모든 사람에게 도움이 되기를 바랍니다.

관련 기사:

Webpack의 자동화된 구성 정보(자세한 튜토리얼)

WeChat 애플릿에서 이미지 업로드와 같은 일련의 기능을 구현하는 방법

웹팩을 위한 범용 데이터 시뮬레이션 프레임워크를 구축하는 방법 프런트 엔드(자세한 튜토리얼)

위 내용은 스크롤 뷰를 사용하여 WeChat 애플릿에서 앵커 슬라이딩을 구현하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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