我创建了一个自定义指令,用于连接mousedown / touchstart和mouseup / touchend事件,这些事件可以向元素添加/删除css3转换(按下/释放效果)。
它适用于桌面Chrome和IE,iOS7和iOS中的iOS,但Android 4.4.2会显示转换,但点击事件永远不会触发实际导航。
我能让它工作的唯一方法是在元素上非常快速地点击/点击。几乎就像使用正常的敲击速度时,点击事件被吞下或取消一样。
我将指令应用于divs和divs中的ng-click指令 - 两者都不起作用。
编辑:有一种情况,它在任何浏览器中都不起作用 - 如果div我添加指令也附加了ng-click。如果我通过添加嵌套div将它添加到DOM中的一个级别并将其应用于该div它可以正常工作。
这是一个包含在链接中的示例div
<a ng-href="#/concept/{{conceptOfDay.id}}">
<div class="contentBox" touch-tilt>
<i class="fa fa-2x icon fa-calendar-o"></i>
<div class="itemTitle">concept of the day</div>
<div class="itemSubTitle">{{conceptOfDay.title}}</div>
</div>
</a>
指令
angular.module('app').directive('touchTilt', ['$document', function ($document) {
var directive = {
restrict: 'A',
link: function (scope, element, attr) {
function mousedown(event) {
var translateString = "perspective( 800px ) rotateX( 0deg ) rotateY( 0deg ) translateZ( -30px )";
element.css('transform', translateString);
$document.on('touchend mouseup', mouseup);
}
function mouseup(event) {
var idleCss = "perspective( 800px ) rotateX( 0deg ) rotateY( 0deg ) translateZ( 0px )";
element.css('transform', idleCss);
$document.off('touchend mouseup', mouseup);
}
element.on('touchstart mousedown', mousedown);
element.click(function () { alert('click event handled'); })
}
};
return directive;
}]);
答案 0 :(得分:0)
通常,您在迁移到Android或触控设备时会使用ngTouch模块。如本文档所述,触摸设备有延迟:
https://docs.angularjs.org/api/ngTouch
您的示例中缺少某些元素,或者您只是以不同的方式执行此操作,因此我不会特别对此进行评论(我倾向于明确使用ngClick)。
无论如何,你应该能够在ngTouch中使用ngClick指令让触摸屏更好地工作。我有一个类似的问题,包括角度触摸解决了不少。
你没有注意到你包含哪些库,所以如果我是多余的那就是原因。
答案 1 :(得分:0)
在链接函数中,您只是声明两个处理函数mousedown和mouseup,但是您永远不会将它们设置为触发。您需要在标记中添加ng-click或将元素绑定到链接函数中的事件侦听器。
// (Inside of link function)
element.bind('mousedown', function(){
console.log('clicked on document');
});