2012-03-05 9 views
1

私は、ターゲットテキストを上に置いたときにアクティブになる(表示する)ツールチップを持っています。タッチデバイスの場合、ユーザーはターゲットテキストをクリックすることができ、ツールチップが表示され、TOOLTIP(ターゲットテキストではない)に触れるとツールチップが非表示になります。しかし、マウスの人がツールチップのテキストを選択できるようにしたいのですが、問題は、ツールチップをクリックすると、タッチデバイスの機能であることです。jQueryを使用すると、タッチは検出されますがクリックはしません。

コンピュータの場合(マウスを使用して)、ツールチップを隠すことなくクリックできるようにしたいが、タッチデバイスではクリックしたときにツールチップを非表示にしてユーザーにとって使いやすくしたい。希望は意味をなさない。

これについてはどのような方法が最適ですか?私が「触ったときにこれを行うが、マウスでクリックしたときにそれをする」と言う方法はありますか?

http://jsfiddle.net/nicktheandroid/fdWW5/4/

+0

http://jquerymobile.com/ –

答えて

2

これはおそらく過剰ですが、これらは、私はブラウザ間でタッチイベントを促進するために使用するいくつかのjQueryの拡張です:

jQuery.fn.touchstart = function (callback) { 
this.each(function() { 
var _self = jQuery(this); 
var onTouchstart = function (ev) { 
    if (ev.originalEvent) { 
    if (ev.originalEvent.targetTouches) { 
     AddTouchPropertiesToJQEventObject(ev); 
     callback.call(this, ev); 
    } 
    } 
}; 
_self.bind('touchstart', onTouchstart); 
}); 
return this; 
}; 

jQuery.fn.touchmove = function (callback) { 
this.each(function() { 
var _self = jQuery(this); 
var onTouchMove = function (ev) { 
    if (ev.originalEvent) { 
    if (ev.originalEvent.targetTouches) { 
     AddTouchPropertiesToJQEventObject(ev); 
     callback.call(this, ev); 
    } 
    } 
}; 
_self.bind('touchmove', onTouchMove); 
}); 
return this; 
}; 

jQuery.fn.touchend = function (callback) { 
this.each(function() { 
var _self = jQuery(this); 
var onTouchEnd = function (ev) { 
    var lastTouchMoveInfo = _self.data('lastTouchMoveInfo'); 
    ev = $.extend(ev, lastTouchMoveInfo); 
    callback.call(this, ev); 
}; 
var onTouchMove = function (ev) { 
    var lastTouchMoveInfo = { 
    pageX: ev.pageX, 
    pageY: ev.pageY, 
    touches: ev.touches 
    }; 
    _self.data('lastTouchMoveInfo', lastTouchMoveInfo); 
}; 
_self.touchstart(onTouchMove); 
_self.touchmove(onTouchMove); 
_self.bind('touchend', onTouchEnd); 
}); 
return this; 
}; 

var AddTouchPropertiesToJQEventObject = function (jqEventObject) { 
    jqEventObject.pageX = jqEventObject.originalEvent.targetTouches[0].pageX; 
    jqEventObject.pageY = jqEventObject.originalEvent.targetTouches[0].pageY; 
    jqEventObject.rotation = jqEventObject.originalEvent.rotation; 
    jqEventObject.scale = jqEventObject.originalEvent.scale; 
    jqEventObject.targetTouches = jqEventObject.originalEvent.targetTouches; 
    jqEventObject.touches = jqEventObject.originalEvent.touches; 
}; 

は基本的にあなたがtouchstarttouchmove、およびtouchendにバインドします。または、あなたがやっていることに対してちょうどtouchstart