From f5139b1689e5cdec89af56eaff1bce1c7bcb59fa Mon Sep 17 00:00:00 2001 From: Tom Hicks Date: Wed, 8 Jul 2015 16:29:27 +0100 Subject: [PATCH] Document shouldRejectClick functionality --- README.md | 30 +++++++++++++++++++++++++++++- 1 file changed, 29 insertions(+), 1 deletion(-) diff --git a/README.md b/README.md index e9995c0383f03..b583c3854c9ed 100644 --- a/README.md +++ b/README.md @@ -30,4 +30,32 @@ var Main = React.createClass({ }); React.render(
, document.body); -``` \ No newline at end of file +``` + +### Ignoring ghost clicks + +When a tap happens, the browser sends a `touchstart` and `touchend`, and then +300ms later, a `click` event. This plugin ignores the click event if it has +been immediately preceeded by a touch event (within 750ms of the last touch +event). + +Occasionally, there may be times when the 750ms threshold is exceeded due to +slow rendering or garbage collection, and this causes the dreaded ghost click. + +The 750ms threshold is pretty good, but sometimes you might want to override +that behaviour. You can do this by supplying your own `shouldRejectClick` +function when you inject the plugin. + +The following example will simply reject all click events, which you might +want to do if you are always using `onTouchTap` and only building for touch +devices: + +```js +var React = require('react'), +injectTapEventPlugin = require("react-tap-event-plugin"); +injectTapEventPlugin({ + shouldRejectClick: function (lastTouchEventTimestamp, clickEventTimestamp) { + return true; + } +}); +```