아래의 코드를 사용하여 끈기있는 탐색을 설정하려고합니다.CSS 변경시 div로 스크롤되는 jQuery (끈적 끈적한 이동)
div가 고정으로 변경 될 때마다 브라우저가 자동으로 스크롤됩니다. 이것은 브라우저가 원래의 탐색 막대가있는 곳보다 더 멀리 스크롤 할 수 없음을 의미합니다.
아이디어가 있으십니까? 귀하의 콘텐츠가 끈적 요소가 position: relative
로 설정되어있을 때, 그것은 충분히 높은하다고 딱 맞는 높이가 수직으로 스크롤하고, 문서 흐름에서 제거 할 때, 그 양은 충분히 높은 더 이상 없을 때
$(document).ready(function() {
var stickNavOffset = $('#nav').offset().top;
function sticky() {
if ($(this).scrollTop() > stickNavOffset-1) {
$('#nav').css({position:'fixed',left:'auto'});
} else {
$('#nav').css({position:'relative',left:'auto'});
}
}
$(window).scroll(function() {
sticky();
});
});
설명하는 문제를 이해하는 데 어려움을 겪고 있습니다. 나는 당신의 코드와 함께 빠른 [피들] (http://jsfiddle.net/nate/LTznp/)을 만들었다. (항상 질문을 게시 할 때 좋은 생각이다.) 당신이 가진 문제를 보여주고 있습니까? 그렇지 않다면 조정할 수 있습니까? – Nate
예 및 아니오. 당신은 바이올린이고, 잘 작동합니다. 하지만 내 사이트에서 자동으로 상단으로 스크롤됩니다. 나는 그것을 랩탑에서 시험해 보았는데 문제가 발생하지 않는다. 시크릿 창에서도 내 데스크톱에 문제가 발생합니다. 그것이 브라우저 문제가 될까요? –
브라우저 동작과 관련이있을 수 있지만 여전히 해결해야 할 부분입니다. :) 그래서 : 문제 해결의 기본 기술 중 하나는 문제를 일으키는 요소를 격리하는 것입니다. 우리는 잘 작동하는 바이올린 설정과 문제가있는 사이트를 가지고 있습니다. 따라서 문제를 재현 할 수있을 때까지 사이트에서 잠재적 요소를 더 많이 추가 할시기입니다. 문제의 원인이되는 구성 요소를 분리하면 솔루션의 3/4을 차지하게됩니다. – Nate