-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathaddTouchClass.js
47 lines (38 loc) · 1.16 KB
/
addTouchClass.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
(function( $ ){
$.fn.addTouchClass = function( className ) {
var ref = this;
function onTouchLeftElement(element) {
$(element).unbind("touchmove", onTouchMove);
$(element).unbind("touchend", onTouchEnd);
$(element).removeClass(className);
}
function onTouchCancel(e) {
e.preventDefault();
onTouchLeftElement(this);
}
function onTouchStart(e) {
e.preventDefault();
$(this).addClass(className);
$(this).bind('touchmove', onTouchMove);
$(this).bind('touchend', onTouchEnd);
$(this).bind('touchcancel', onTouchCancel);
}
function onTouchMove(e) {
e.preventDefault();
var originalEvent = e.originalEvent;
var targetTouch = originalEvent.targetTouches[0];
var theTarget = document.elementFromPoint(targetTouch.clientX, targetTouch.clientY);
if (theTarget !== this) {
onTouchLeftElement(this);
}
}
function onTouchEnd(e) {
e.preventDefault();
onTouchLeftElement(this);
}
return ref.each(function() {
var $this = $(this);
$this.bind('touchstart', onTouchStart);
});
};
})( jQuery );