This簡単なコードです:実際になぜ右クリックが.click()でトリガされないのですか?
HTML
<a id="link" href="#">Ciao</a>
jQueryの
$('#link').click(function() {
alert("ciao");
});
、ミドル/左ボタンがトリガー(アラートが印刷されます)が、右クリックとは?何故なの?そして私はどのようにそれを引き起こすことができますか?左、真ん中、右クリックを処理するため
This簡単なコードです:実際になぜ右クリックが.click()でトリガされないのですか?
<a id="link" href="#">Ciao</a>
$('#link').click(function() {
alert("ciao");
});
、ミドル/左ボタンがトリガー(アラートが印刷されます)が、右クリックとは?何故なの?そして私はどのようにそれを引き起こすことができますか?左、真ん中、右クリックを処理するため
バインドmousedown
:
$('#link').mousedown(function(e) {
alert("ciao");
});
あなたは、ボタンがクリックされた確定にe.which
を使用することができます。 1
:左、2
:中、3
:右。 http://jsfiddle.net/fPhDg/9/
あなたはこのように表示されてからコンテキストメニューを停止することができます:
$('#link').contextmenu(false);
あなたは非常に非常に慎重にこれを使用する必要があります
はここでデモです!ごくまれにしか意味がありません。
そして、「コードスチール」の想像上の恐怖ではなく、非常に正当な理由でそれを使用してください。コンテキストメニューを無効にすると、重要なブラウザ機能が無効になり、一部のユーザーが邪魔になることがあります。このイベントをバインドできないブラウザを使用することさえあります。 –
@markzzz左、中央、右のボタンをクリックすると、機能をトリガーしたいと思ったのですが?右ボタンを探しているだけの場合は '.contextmenu(fn)'を使います。 –
ブラウザのコンテキストメニューを削除したいのですが?だから、右クリックしてブラウザのウィンドウを表示せずに? – markzzz
使用.contextmenu(...)
:
$('#link').contextmenu(function() {
alert("ciao");
});
そして、あなたは両方のイベントをキャッチしたい場合は、bind(...)
機能を使用できます:あなたはこのように、マウスの右クリックをキャプチャすることができます
$('#link').bind('click contextmenu',function()
{
alert("ciao");
});
を:
<head>
<script>
function whichButton(event)
{
if (event.button==2)
{
alert("You clicked the right mouse button!");
}
else
{
alert("You clicked the left mouse button!");
}
}
</script>
</head>
<body onmousedown="whichButton(event)">
<p>Click in the document. An alert box will alert which mouse button you clicked.</p>
</body>
あなたは、クリックイベントなどそのコンテキストメニューイベントをサブスクライブすることができます
$('#link').on('click contextmenu', function (e) {
if (e.which === 3) {
// Right mousebutton was clicked
// 1 is left mousebutton
// 2 is centre mousebutton
}
});
はこれを試して...
$('#link').mousedown(function (event) {
if(event.which === 1)
alert("left click");
if(event.which === 2)
alert("center click");
if(event.which === 3)
alert("right clikc");
});
関連します。http:// stackoverflowの.com/questions/1646851/jquery-right-click-event – David