检测在文本中右键单击的单词

时间:2017-04-23 12:21:01

标签: javascript jquery html uwp

对于我的应用程序,我想在有人点击右键时显示​​自定义上下文菜单。如果右键单击任何单词,我想为它显示一些额外的选项。我抬头看网,我找到了解决左键单击时如何获取单词的解决方案,我尝试修改它以进行右键单击但不知道它无法正常工作。

下面的代码,左键单击它会显示带有单词的警告,并且在执行右键单击时,预计会执行相同的操作。但有时它不显示任何弹出窗口,当它在弹出窗口中显示前一个右键单击的单词时。

$('.text123').click(function(e){
   s = window.getSelection();
   var range = s.getRangeAt(0);
   var node = s.anchorNode;
   while(range.toString().indexOf(' ') != 0) {                 
     range.setStart(node,(range.startOffset -1));
   }
   range.setStart(node, range.startOffset +1);
   do{
     range.setEnd(node,range.endOffset + 1);
   }while(range.toString().indexOf(' ') == -1 && range.toString().trim() != '');
   var str = range.toString().trim();
   alert(str);
});

$(".text123").mouseup(function(){
   var e = window.event;
   if (e.button == 2)
   {
     jQuery(document.elementFromPoint(e.pageX, e.pageY)).click();
   }
});

我正在 Edge 浏览器上进行测试,因为我想在UWP应用中使用该代码。

2 个答案:

答案 0 :(得分:5)

经过一些搜索和测试,这似乎适用于EDGE。

JSFiddle demo.

这是主要的变化:

$(".text123").on('contextmenu', function(evt){
   evt.preventDefault(); // with this the context menu will not open
   var e = window.event;
   if (e.button == 2) {
     /* START - And this make the selection before emulate the left click */
     var range = document.caretRangeFromPoint(e.pageX, e.pageY);
     var selection = window.getSelection();
     selection.removeAllRanges();
     selection.addRange(range);
     /* END */
     jQuery(document.elementFromPoint(e.pageX, e.pageY)).click();
   }
});

<强>更新

此更新用于回答滚动页面问题以及第一个和最后一个单词选择错误。

The new JSFiddle.

$('.text123').click(function(e) {
    s = window.getSelection();
    var range = s.getRangeAt(0);
    var node = s.anchorNode;

    // ###  && range.startOffset != 0 <--- This check very first char
    while (range.toString().indexOf(' ') != 0 && range.startOffset != 0) {
        range.setStart(node, (range.startOffset - 1));
    }
    range.setStart(node, range.startOffset + 1);


    do {
        range.setEnd(node, range.endOffset + 1);
    } while (range.toString().indexOf(' ') == -1 && range.toString().trim() != '' && range.endOffset < range.endContainer.length);
    // ### && range.endOffset < range.endContainer.length <--- This check the last char

    var str = range.toString().trim();

    alert(str);
});


$(".text123").on('contextmenu', function(evt) {
    evt.preventDefault();
    var e = window.event;
    if (e.button == 2) {
        // ### - $(document).scrollTop() <--- This will fix the page scroll
        var range = document.caretRangeFromPoint(e.pageX, e.pageY - $(document).scrollTop()); 
        var selection = window.getSelection();
        selection.removeAllRanges();
        selection.addRange(range);
        // ### - $(document).scrollTop() <--- This will fix the page scroll
        jQuery(document.elementFromPoint(e.pageX, e.pageY - $(document).scrollTop())).click(); 
    }
});

答案 1 :(得分:0)

在您使用右键单击重新考虑投入更多时间之前。

为什么?:辅助功能和用户体验:

  • 右键单击在移动设备上无法均等访问
  • 大多数拥有一键鼠标的Mac用户很少使用右键单击。

如果您仍然热衷于右键单击,请参阅此主题,其中包含有关右键单击事件的一些有用讨论:

Is right click a Javascript event?