Ho un'applicazione basata sul Web che include un componente che l'utente può scorrere su e giù con il dito. Uso il metodo preventDefault dell'evento per impedire il comportamento predefinito in cui il tocco sposta sposta l'intero schermo sui dispositivi iOS.Come impedire il comportamento predefinito dell'evento touchmove in iOS 5?
Purtroppo questo non sembra funzionare più in iOS 5, che ho appena aggiornato a questa mattina. Devo supporre che questo sia fatto in modo diverso in iOS 5, ma devo ancora essere in grado di trovare una risorsa che fornisce istruzioni.
Grazie!
Aggiornamento n. 1: non sono stato in grado di trovare una risposta alla mia domanda specifica, ma sono stato in grado di regolare un po 'il mio codice per utilizzare lo stile di scorrimento -webkit-overflow (impostato su un valore di "touch" ") e implementa la snervante capacità di scorrimento inerziale (dove il contenuto scorre più veloce a seconda della velocità del tuo scorrimento e rimbalza" elastico "indietro se colpisce i confini.) Aspetto molto bello ...
Aggiornamento # 2: Ho un altro strano problema ora, per qualche strana ragione che il comportamento di scorrimento a sfioro si confonde a volte per cui devi trascinare il dito a sinistra ea destra sull'elemento che lo contiene per far sì che il suo contenuto si muova su e giù. per capire perché questo accade - qualcuno ha qualche idea ???
forse si potrebbe fare un po 'di logica controllo come 'if ($ (e.currentTarget) css ('overflow') = 'scroll'!) e .preventDefault(); '. Dal momento che document.ontouchmove sparerà dopo che l'elemento scileble è stato premuto, è possibile eseguire 'el.ontouchmove = function() {allowScroll = true}' e quindi fare in modo che 'document.ontouchmove' utilizzi quel valore per determinare l'azione e quindi reimpostare il valore a falso –
@BrianNickel Grazie per il suggerimento. Questo è un passo nella giusta direzione che ti consentirà di evitare lo scorrimento diretto su base elemento per elemento (incluso lo scorrimento diretto sul corpo), ma se l'utente tocca un elemento scorrevole che è già sul bordo del suo scrollabile gamma, finirà comunque per scorrere il corpo (mostrando la biancheria grigia sotto). Forse l'unico modo è quello di interpretare la direzione del touchmove e verificare se l'elemento è al limite del suo raggio di scorrimento? –
@RyanRapp Grazie per la risposta.Forse non ho descritto abbastanza chiaramente di quale comportamento sto parlando. Con iOS 4 userei e.preventDefault() all'interno di un elemento (ad esempio, un DIV) con il gestore di eventi touchmove di overflow in modo tale da poter spostare il contenuto intorno tramite il posizionamento assoluto basato sul movimento del dito all'interno dell'elemento. Ora e.preventDefault() lo blocca quando provo a muovere il dito l'intera pagina, che non ha abbastanza contenuti da far scorrere, non scorre tanto ma si sposta in modo da poter vedere la trama dello sfondo di Safari dietro di essa. – natlee75