>  기사  >  위챗 애플릿  >  스크롤 뷰는 WeChat 애플릿에서 앵커 슬라이딩을 구현합니다.

스크롤 뷰는 WeChat 애플릿에서 앵커 슬라이딩을 구현합니다.

不言
不言원래의
2018-06-27 17:52:374577검색

이 글은 주로 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)로 설정하는 것입니다.

위 내용은 이 글의 전체 내용입니다. 모든 분들의 학습에 도움이 되었으면 좋겠습니다. 더 많은 관련 내용은 PHP 중국어 홈페이지를 주목해주세요!

관련 권장 사항:

WeChat 애플릿 es6-promise.js는 요청을 캡슐화하고 비동기 프로세스를 처리합니다.


WeChat 애플릿이 이미지 구성 요소 사진의 적응형 너비 비율 표시 방법을 구현하는 방법


WeChat 애플릿 네트워크 소개 wx.request


요청

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

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