正如已经回答的那样,无法捕获浏览器上下文菜单删除的使用情况,事实上,使用
.bind('copy', func....)
不仅将监听上下文菜单的复制,还会监听实际绑定到剪贴板的
CTRL+c
。我编写了一个插件,说实话有点粗糙,但它可以让你捕捉:
上下文复制、剪切、粘贴、删除 - ONLY上下文复制、剪切、粘贴、删除 - AND - CTRL+c, CTRL+x, CTRL+v或者只是上述方法中的一个、两个、三个或四个项目。当然,一个问题是IE不会触发jQuery的
.bind('input', func....
来监听更改,因此我需要为IE触发它,因此可能会有一个非常小的延迟(毫秒级)。
该插件:
(function($) {
$.fn.contextDelete = function(options) {
var set = {
'obj': $(this),
'menu': false,
'paste': false,
'cut': false,
'copy': false,
'set': '',
'ie': null,
};
var opts = $.extend({
'contextDelete': function() {},
'paste': function() {},
'cut': function() {},
'copy': function() {},
'contextOnly': false,
}, options);
$(window).bind({
click: function() {
set.menu = false;
},
keyup: function() {
set.menu = false;
}
});
set.obj.bind({
contextmenu: function() {
set.menu = true;
set.paste = false;
set.cut = false;
set.copy = false;
set.val = set.obj.val();
if ($.browser.msie) {
set.ie = setInterval(function() {
set.obj.trigger($.Event('input'));
if (!set.menu) {
clearInterval(set.ie);
}
}, 300);
}
},
paste: function(e) {
set.paste = true;
if (opts.contextOnly) {
if (set.menu) {
opts.paste(e);
set.menu = false;
}
}
else {
opts.paste(e);
}
},
cut: function(e) {
set.cut = true;
if (opts.contextOnly) {
if (set.menu) {
opts.cut(e);
set.menu = false;
}
}
else {
opts.cut(e);
}
},
copy: function(e) {
set.copy = true;
if (opts.contextOnly) {
if (set.menu) {
opts.copy(e);
set.menu = false;
}
}
else {
opts.copy(e);
}
},
input: function(e) {
if (set.menu && (!set.paste) && (!set.cut) && (!set.copy)) {
if (set.obj.val().length < set.val.length) {
opts.contextDelete(e);
set.menu = false;
}
}
}
});
};
})(jQuery);
一个示例用法,上下文菜单删除 + 上下文菜单复制仅限于此:
$('#evalname').contextDelete({
contextDelete: function(e) {
alert('You just deleted something!');
},
copy: function(e) {
alert('You just copied something!');
},
contextOnly: true,
});
Click Here for a DEMO