모바일 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 중국어 웹사이트의 기타 관련 기사를 참조하세요!