당겨서 새로고침 및 오버플로 효과를 맞춤설정하여 스크롤을 관리하세요

요약

CSS overscroll-behavior 속성을 사용하면 개발자가 콘텐츠의 상단/하단에 도달할 때 브라우저의 기본 오버플로 스크롤 동작을 재정의할 수 있습니다. 당겨서 새로고침을 사용 중지하는 사용 사례 오버스크롤 발광 효과와 고무밴드 효과 삭제, 모달/오버레이 아래에 있을 때 페이지 콘텐츠가 스크롤되지 않도록 합니다.

배경

스크롤 경계 및 스크롤 체인

<ph type="x-smartling-placeholder">
</ph>
Chrome Android의 스크롤 체이닝

스크롤은 페이지와 상호작용하는 가장 기본적인 방법 중 하나이지만 브라우저의 별난 특징 때문에 특정 UX 패턴을 처리하기가 까다로울 수 있습니다. 기본 동작입니다. 예를 들어 많은 수의 사용자가 스크롤해야 할 수도 있는 항목을 표시합니다. 최저치에 도달하면 오버플로 컨테이너가 스크롤을 중지합니다. 즉, 사용자는 '스크롤 경계'에 도달합니다. 하지만 사용자가 계속 스크롤하면 어떻게 되는지 확인해 보세요. 뒤에 있는 콘텐츠가 스크롤을 시작합니다. 스크롤 상위 컨테이너가 인계받아 작업합니다. 기본 페이지 자체를 예로 들 수 있습니다.

이 동작을 스크롤 체이닝이라고 합니다. 콘텐츠를 스크롤할 때 브라우저의 기본 동작입니다. 종종 기본이 꽤 좋지만 때로는 바람직하지 않거나 예상치 못한 경우도 있습니다. 특정 앱에서는 사용자가 스크롤 경계에 도달하면 다른 사용자 환경을 제공합니다.

당겨서 새로고침 효과

풀업 새로고침은 Facebook 및 트위터와 같은 모바일 앱에서 대중화된 직관적인 동작입니다. 소셜 피드를 내리고 놓으면 더 많은 최근 게시물을 로드할 수 있습니다. 실제로 이 특정 UX는 너무 인기가 많아서 Android의 Chrome과 같은 모바일 브라우저에서도 동일한 효과를 채택했습니다. 페이지 상단에서 아래로 스와이프하면 전체 페이지가 새로고침됩니다.

<ph type="x-smartling-placeholder">
</ph>
트위터에서 피드를 새로고침할 때
당겨서 새로고침하는 커스텀 PWA에 관한 것입니다.
<ph type="x-smartling-placeholder">
</ph>
Chrome Android의 기본 '당겨서 새로고침' 기능을 통해
있습니다.

트위터 PWA와 같은 상황의 경우 네이티브 당겨서 새로고침 작업을 사용 중지하는 것이 바람직할 수 있습니다. 왜냐하면 이 사용자가 실수로 페이지를 새로고침하는 일이 없도록 해야 합니다. 새로고침 애니메이션이 두 번 표시될 수도 있습니다. 또는 브라우저의 동작을 더욱 멋지게 맞춤설정하고 사이트의 브랜드 인지도 제고를 목표로 하는 광고주 안타깝게도, 이러한 유형의 맞춤설정은 분리하기가 까다롭습니다. 개발자가 불필요한 자바스크립트를 작성하게 되므로 비수동 터치 리스너 (스크롤 차단) 또는 전체 페이지를 100vw/vh로 고정 <div> (페이지 오버플로 방지) 이러한 해결 방법은 스크롤 성능에 잘 문서화된 부정적인 영향을 미칩니다.

더 나은 서비스를 제공할 수 있습니다.

overscroll-behavior 소개

overscroll-behavior 속성은 컨테이너를 오버스크롤할 때 발생하는 동작( 페이지 자체). 이를 사용하여 스크롤 체인을 취소하거나, 당겨서 새로고침 작업, iOS에서 고무밴드 효과 사용 중지 (Safari의 경우 구현 overscroll-behavior) 등이 있습니다. 가장 좋은 점은 overscroll-behavior를 사용해도 부정적인 영향을 페이지 성능을 개선할 수 있습니다.

이 속성은 다음 세 가지 값을 사용할 수 있습니다.

  1. auto - 기본값입니다. 요소에서 시작된 스크롤이 조상 요소로 전파될 수 있습니다.
  2. contain - 스크롤 체인을 방지합니다. 스크롤이 상위 요소에 전파되지 않음 노드 내의 국소적인 효과가 표시됩니다. 예를 들어 오버스크롤 발광 효과는 사용자에게 알리는 고무밴드 효과, Android의 경우 스크롤 경계에 도달하면 발생합니다 참고: html 요소의 overscroll-behavior: contain이 오버스크롤을 방지함 탐색 작업
  3. none - contain와 같지만 내부에서 오버스크롤 효과도 방지합니다. 노드 자체 (예: Android 오버스크롤 글로우 또는 iOS 러버밴딩)

overscroll-behavior 사용 방법을 알아보기 위해 몇 가지 예를 살펴보겠습니다.

스크롤이 고정 위치 요소를 이스케이프하지 않도록 방지

채팅 상자 시나리오

채팅 창 아래의 콘텐츠도 스크롤됨 :(

페이지 하단에 고정된 채팅창을 예로 들 수 있습니다. 이 채팅 상자가 독립 실행형 구성요소이며 콘텐츠를 분리할 수 있습니다 그러나 스크롤 체인으로 인해 사용자가 채팅에서 마지막 메시지를 입력하는 즉시 문서가 스크롤되기 시작함 기록.

이 앱의 경우 채팅창 내에서 시작된 스크롤이 채팅 내에 유지되는 것이 더 적절합니다. 이렇게 하려면 채팅 메시지가 포함된 요소에 overscroll-behavior: contain를 추가합니다.

#chat .msgs {
  overflow: auto;
  overscroll-behavior: contain;
  height: 300px;
}

기본적으로 채팅 상자의 스크롤과 기본 페이지가 표시됩니다. 최종 결과는 사용자가 채팅 기록의 상단/하단에 도달해도 기본 페이지가 유지된다는 것입니다. 다음에서 시작하는 스크롤 채팅 상자가 전파되지 않습니다.

페이지 오버레이 시나리오

'아래 스크롤' 시나리오의 또 다른 변형은 고정된 위치 오버레이 뒤에서 스크롤되는 콘텐츠가 표시되는 경우입니다. 죽은 경품 overscroll-behavior 일정을 완료했습니다. 브라우저는 사용자가 도움을 주려고 결국 사이트에 버그가 생기게 됩니다.

- overscroll-behavior: contain 유무와 관계없는 모달

이전: 페이지 콘텐츠가 오버레이 아래로 스크롤됩니다.
<ph type="x-smartling-placeholder">
</ph>
뒤에: 페이지 콘텐츠가 오버레이 아래로 스크롤되지 않습니다.

당겨서 새로고침 사용 중지

당겨서 새로고침 작업을 사용 중지하는 작업은 한 줄의 CSS로 수행할 수 있습니다. 전체 뷰포인트 정의 요소에서 스크롤 체이닝을 방지하기만 하면 됩니다. 대부분의 경우 <html> 또는 <body>입니다.

body {
  /* Disables pull-to-refresh but allows overscroll glow effects. */
  overscroll-behavior-y: contain;
}

이렇게 간단하게 추가하면 채팅창 데모에서 두 번의 새로고침 풀 애니메이션을 수정하고 더 깔끔한 로드 애니메이션을 사용하는 맞춤 효과를 구현할 수 있습니다. 이 받은편지함이 새로고침되면서 전체 받은편지함도 흐려집니다.

<ph type="x-smartling-placeholder">
</ph>
이전
<ph type="x-smartling-placeholder">
</ph>
이후

이것은 전체 코드를 확인하세요.

<style>
  body.refreshing #inbox {
    filter: blur(1px);
    touch-action: none; /* prevent scrolling */
  }
  body.refreshing .refresher {
    transform: translate3d(0,150%,0) scale(1);
    z-index: 1;
  }
  .refresher {
    --refresh-width: 55px;
    pointer-events: none;
    width: var(--refresh-width);
    height: var(--refresh-width);
    border-radius: 50%;
    position: absolute;
    transition: all 300ms cubic-bezier(0,0,0.2,1);
    will-change: transform, opacity;
    ...
  }
</style>

<div class="refresher">
  <div class="loading-bar"></div>
  <div class="loading-bar"></div>
  <div class="loading-bar"></div>
  <div class="loading-bar"></div>
</div>

<section id="inbox"><!-- msgs --></section>

<script>
  let _startY;
  const inbox = document.querySelector('#inbox');

  inbox.addEventListener('touchstart', e => {
    _startY = e.touches[0].pageY;
  }, {passive: true});

  inbox.addEventListener('touchmove', e => {
    const y = e.touches[0].pageY;
    // Activate custom pull-to-refresh effects when at the top of the container
    // and user is scrolling up.
    if (document.scrollingElement.scrollTop === 0 && y > _startY &&
        !document.body.classList.contains('refreshing')) {
      // refresh inbox.
    }
  }, {passive: true});
</script>

오버스크롤 발광 및 고무밴딩 효과 사용 중지

스크롤 경계에 도달할 때 반동 효과를 사용 중지하려면 overscroll-behavior-y: none를 사용합니다.

body {
  /* Disables pull-to-refresh and overscroll glow effect.
     Still keeps swipe navigations. */
  overscroll-behavior-y: none;
}
이전: 스크롤 경계에 도달하면 글로우가 표시됩니다.
이후: 발광이 사용 중지됩니다.

전체 데모

종합해 보면, 채팅 상자 데모 사용 overscroll-behavior: 당겨서 새로고침 맞춤 애니메이션 만들기 스크롤의 채팅 상자 위젯 이스케이프를 사용 중지합니다. 이렇게 하면 CSS overscroll-behavior 없이는 달성하기 어려운 최적의 사용자 환경을 제공할 수 있습니다.

데모 보기 | 소스