最新消息:雨落星辰是一个专注网站SEO优化、网站SEO诊断、搜索引擎研究、网络营销推广、网站策划运营及站长类的自媒体原创博客

javascript - In AngularJS how can I modify ng-click to fire on touchEnd on mobile? - Stack Overflow

programmeradmin0浏览0评论

Right now I'm detecting if the user's browser has touch events and listening for touchend instead of click on certain elements (to get over the 'wait-for-double-click' lag). It works great on a slide-out drawer I'm using.

I want to modify my app so that elements with ng-click="function()" will respond on click events for desktop (no touch events available) and respond on touchend for touch devices.

I'd rather not create a new directive for ng-touch or something and instead just modify the ng-click directive. I'm not sure how to modify a built-in Angular directive, though.

Is there a way to do this?

Here's a rough JS fiddle I started, but didn't get too far:

/

Right now I'm detecting if the user's browser has touch events and listening for touchend instead of click on certain elements (to get over the 'wait-for-double-click' lag). It works great on a slide-out drawer I'm using.

I want to modify my app so that elements with ng-click="function()" will respond on click events for desktop (no touch events available) and respond on touchend for touch devices.

I'd rather not create a new directive for ng-touch or something and instead just modify the ng-click directive. I'm not sure how to modify a built-in Angular directive, though.

Is there a way to do this?

Here's a rough JS fiddle I started, but didn't get too far:

http://jsfiddle/MTh8U/

Share Improve this question asked Jan 7, 2014 at 4:41 KeithKeith 4,2247 gold badges28 silver badges43 bronze badges
Add a ment  | 

1 Answer 1

Reset to default 7

It actually sounds like you're trying to duplicate what Angular has already created for mobile: http://docs.angularjs/api/ngTouch. Note that this is just another dependency you'll need to inject.

发布评论

评论列表(0)

  1. 暂无评论