Eliminate 300ms delay on click events in mobile Safari

后端 未结 10 2125
北恋
北恋 2020-11-28 18:34

I\'ve read that mobile Safari has a 300ms delay on click events from the time the link/button is clicked to the time the event fires. The reason for the delay is to wait to

相关标签:
10条回答
  • 2020-11-28 18:49

    This plugin -FastClick developed by Financial Times does it perfectly for you!

    Make sure though to add event.stopPropagation(); and/or event.preventDefault(); directly after the click function, otherwise it might run twice as it did for me, i.e.:

    $("#buttonId").on('click',function(event){
        event.stopPropagation(); event.preventDefault();
       //do your magic
    
    });
    
    0 讨论(0)
  • 2020-11-28 18:50

    In jQuery you can bind "touchend" event, witch trigger code inmediatly after tap (is like a keydown in keyboard). Tested on current Chrome and Firefox tablet versions. Don't forget "click" also, for your touch screen laptops and desktop devices.

    jQuery('.yourElements').bind('click touchend',function(event){
    
        event.stopPropagation();
        event.preventDefault();
    
    	// everything else
    });

    0 讨论(0)
  • 2020-11-28 18:54

    I've come across a hugely popular alternative called Hammer.js (Github page) which I think is the best approach.

    Hammer.js is a more full-featured touch library (has many swipe commands) than Fastclick.js (most upvoted answer).

    Beware though: scrolling fast on mobile devices tends to really lock up the UI when you use either Hammer.js or Fastclick.js. This is a major problem if your site has a newsfeed or an interface where users will be scrolling a lot (would seem like most web apps). For this reason, I'm using neither of these plugins at the moment.

    0 讨论(0)
  • 2020-11-28 18:57

    Now some mobile browsers eliminate 300 ms click delay if you set the viewport. You don't need to use workarounds anymore.

    <meta name="viewport" content="width=device-width, user-scalable=no">
    

    This is currently supported Chrome for Android, Firefox for Android and Safari for iOS

    However on iOS Safari, double-tap is a scroll gesture on unzoomable pages. For that reason they can't remove the 300ms delay. If they can't remove the delay on unzoomable pages, they're unlikely to remove it on zoomable pages.

    Windows Phones also retain the 300ms delay on unzoomable pages, but they don't have an alternative gesture like iOS so it's possible for them to remove this delay as Chrome has. You can remove the delay on Windows Phone using:

    html {
    -ms-touch-action: manipulation;
    touch-action: manipulation;
    }
    

    Source: http://updates.html5rocks.com/2013/12/300ms-tap-delay-gone-away

    UPDATE 2015 December

    Until now, WebKit and Safari on iOS had a 350ms delay before single taps activate links or buttons to allow people to zoom into pages with a double tap. Chrome changed this a couple of months ago already by using a smarter algorithm to detect that and WebKit will follow with a similar approach. The article gives some great insights how browsers work with touch gestures and how browsers can still get so much smarter than they are today.

    UPDATE 2016 March

    On Safari for iOS, the 350 ms wait time to detect a second tap has been removed to create a “fast-tap” response. This is enabled for pages that declare a viewport with either width=device-width or user-scalable=no. Authors can also opt in to fast-tap behavior on specific elements by using the CSS touch-action: manipulation as documented here (scroll down to the 'Styling Fast-Tap Behavior' heading) and here.

    0 讨论(0)
提交回复
热议问题