> 웹 프론트엔드 > CSS 튜토리얼 > 모바일 Chrome에서 전체 화면 배경 이미지가 점프하는 이유는 무엇이며 어떻게 해결할 수 있습니까?

모바일 Chrome에서 전체 화면 배경 이미지가 점프하는 이유는 무엇이며 어떻게 해결할 수 있습니까?

Linda Hamilton
풀어 주다: 2024-12-06 00:03:13
원래의
720명이 탐색했습니다.

Why Does My Full-Screen Background Image Jump in Mobile Chrome and How Can I Fix It?

모바일 Chrome의 배경 이미지 오프셋 문제

반응형 웹 디자인에서는 크기 조정과 원활하게 전환되는 전체 화면 배경 이미지를 사용하는 것이 일반적입니다. . 그러나 개발자들은 아래로 스크롤할 때 iOS Safari, Android 브라우저 또는 Android용 Chrome의 주소 표시줄이 숨겨지는 경우 배경이 갑자기 점프하는 문제에 자주 직면합니다.

문제 원인

배경 크기 값이 "cover"인 고정 높이 배경 div를 사용할 때 문제가 발생합니다. 주소 표시줄이 줄어들면 배경 div의 높이가 변경되어 사용 가능한 영역을 포함하도록 이미지의 크기와 위치가 다시 조정됩니다.

해결책 1: #bg1 및 #bg2 높이를 100vh로 설정

배경 div 높이를 100vh(뷰포트 높이)로 설정하려고 하면 그러나 iOS에는 이 접근 방식이 안정적으로 작동하지 못하게 하는 vh 버그가 있습니다.

해결책 2: Javascript를 사용하여 정적 높이 설정

뷰포트 크기는 다음에 의해 결정되므로 Javascript는 URL 표시줄의 영향을 받지 않습니다. Javascript를 사용하여 뷰포트 크기에 따라 배경 div에 정적 높이를 설정할 수 있습니다. 이는 이상적인 솔루션은 아니지만 배경 이미지 크기 조정을 효과적으로 방지합니다.

var bg = $("#bg1, #bg2");

function resizeBackground() {
    bg.height($(window).height());
}

$(window).resize(resizeBackground);
resizeBackground();
로그인 후 복사

추가 참고 사항

이 문제의 원인은 다음과 같습니다. iOS 및 Android 플랫폼의 주소 표시줄 크기 조정. 이러한 브라우저의 최신 변경 사항은 스크롤 트릭을 사용하여 페이지 로드 시 URL 표시줄이 숨겨지는 것을 방지합니다.

스크롤 간격 해결

위 스크립트는 배경이 숨겨지는 것을 효과적으로 방지합니다. 크기가 조정되지만 사용자가 아래로 스크롤할 때 눈에 띄는 간격이 발생할 수 있습니다. 이 문제를 해결하려면 배경 높이에 60px을 추가하세요.

function resizeBackground() {
    bg.height( $(window).height() + 60);
}
로그인 후 복사

이 수정으로 공백이 방지되지만 URL 표시줄이 있을 때 배경 이미지의 하단 60px가 숨겨질 수 있습니다.

위 내용은 모바일 Chrome에서 전체 화면 배경 이미지가 점프하는 이유는 무엇이며 어떻게 해결할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿