Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

Creating and firing touch events on a touch enabled browser?

I am trying to fire touch events in my javascript to simulate user interactions for the purpose of testing features. I have tried the following snippet:

try {
    var targetElement = document.elementFromPoint(55, 155);
    console.log(targetElement);
    var evt = document.createEvent('UIEvent');
    evt.initTouchEvent('touchstart', true, true);

    evt.view = window;
    evt.altKey = false;
    evt.ctrlKey = false;
    evt.shiftKey = false;
    evt.metaKey = false;

    targetElement.dispatchEvent(evt);
} catch (except){
    alert(except);
}

The above code throws the exception 'TypeError: Result of expression 'evt.initTouchEvent[undefined]' is not a function.'

Can somebody point out what I'm doing wrong?

like image 464
prk Avatar asked Apr 19 '11 08:04

prk


1 Answers

According to w3c touch spec, TouchEvent is a subclass of UIEvent. Try creating it like:

var evt = document.createEvent('TouchEvent');
like image 137
vbence Avatar answered Oct 25 '22 03:10

vbence