2012-06-26 16 views
9

Sto utilizzando il JQuery scrollTo plugin sul nostro one-page site per scorrere verticalmente tra le diverse sezioni.Il plugin JQuery scrollTo diventa Jerky su iOS

La pergamena funziona bene in tutti i browser eccetto iOS Safari che scorre ma è molto a scatti. Sto usando un numero di altri plugin Jquery nella pagina, quindi potrebbe essere un conflitto con uno di questi.

Se qualcuno conosce un'alternativa a scrollTo che funziona senza problemi sull'iPad o può suggerire da dove iniziare ad affrontare il problema, apprezzerei l'aiuto. Ho provato this solution ma senza successo.

+1

non hai bisogno di un plugin per questo. jQuery ha .scrollTop dal 1.2.6 http://api.jquery.com/scrollTop/ Puoi persino animare usando il metodo animato. Come .animate ({scrollTop: 0}, 2000, 'ease') correlato a – demux

+0

: http://stackoverflow.com/questions/8970740/ios-safari-scroll-to-top-does-not-work-on-certain -pages-why – demux

+1

il plugin scrollTo ha ancora molte funzionalità avanzate che il core scroll di vanilla non ha. – squarecandy

risposta

1

Grazie per il suggerimento Arnar.

Il tuo consiglio mi ha messo sulla strada giusta e con l'aiuto di this JSFiddle ora ho esattamente lo smooth scroll i wanted to achieve con scorrimento animato liscio a ciascuna sezione e l'evidenziazione automatica della voce di menu attiva.

// Cache selectors 
var lastId, 
    topMenu = $("#top-menu"), 
    topMenuHeight = topMenu.outerHeight()+15, 
    // All list items 
    menuItems = topMenu.find("a"), 
    // Anchors corresponding to menu items 
    scrollItems = menuItems.map(function(){ 
     var item = $($(this).attr("href")); 
     if (item.length) { return item; } 
    }); 

// Bind click handler to menu items 
// so we can get a fancy scroll animation 
menuItems.click(function(e){ 
    var href = $(this).attr("href"), 
     offsetTop = href === "#" ? 0 : $(href).offset().top-topMenuHeight+1; 
    $('html, body').stop().animate({ 
     scrollTop: offsetTop 
    }, 300); 
    e.preventDefault(); 
}); 

// Bind to scroll 
$(window).scroll(function(){ 
    // Get container scroll position 
    var fromTop = $(this).scrollTop()+topMenuHeight; 

    // Get id of current scroll item 
    var cur = scrollItems.map(function(){ 
    if ($(this).offset().top < fromTop) 
     return this; 
    }); 
    // Get the id of the current element 
    cur = cur[cur.length-1]; 
    var id = cur && cur.length ? cur[0].id : ""; 

    if (lastId !== id) { 
     lastId = id; 
     // Set/remove active class 
     menuItems 
     .parent().removeClass("active") 
     .end().filter("[href=#"+id+"]").parent().addClass("active"); 
    }     
}); 
14

provare questo

$.scrollTo(SELECTOR, 800, { 
    'axis':'y' 
}); 
+1

mi hai salvato amico! Grazie! Un post di 2 anni e hai postato un mese fa, e ho usato questa soluzione solo ora ... coincidenza? LOL – otinanai