How to get word under cursor?
Assuming there is a mousestop
event attached to the entire document, what is the best way to figure out the exact word under the cursor (if there is any text), when the mouse stops moving?
I can get the underlying (jQuery) element from the event handler - $(document.elementFromPoint(e.clientX, e.clientY))
- but then what is next?
So开发者_运维技巧 far my idea is to replace all text nodes within hit element with their copy where each word is wrapped in a DOM element (don't know which one yet) and then call $(document.elementFromPoint(e.clientX, e.clientY))
again to get the element that contains only the word under mouse.
Well, no magic tricks so far, so here is the dull boring (and yet working) solution:
$(document.body).mousemove(function(e){
var onmousestop = function() {
function getHitWord(hit_elem) {
var hit_word = '';
hit_elem = $(hit_elem);
//text contents of hit element
var text_nodes = hit_elem.contents().filter(function(){
return this.nodeType == Node.TEXT_NODE && this.nodeValue.match(/[a-zA-Z]{2,}/)
});
//bunch of text under cursor? break it into words
if (text_nodes.length > 0) {
var original_content = hit_elem.clone();
//wrap every word in every node in a dom element
text_nodes.replaceWith(function(i) {
return $(this).text().replace(/([a-zA-Z-]*)/g, "<word>$1</word>")
});
//get the exact word under cursor
var hit_word_elem = document.elementFromPoint(e.clientX, e.clientY);
if (hit_word_elem.nodeName != 'WORD') {
console.log("missed!");
}
else {
hit_word = $(hit_word_elem).text();
console.log("got it: "+hit_word);
}
hit_elem.replaceWith(original_content);
}
return hit_word;
}
var hit_word = getHitWord(document.elementFromPoint(e.clientX, e.clientY));
...
}
}
There are few other subtleties involved (like event 'noise reduction', keeping replaced dom context (such as selection) and so forth), but you get the idea.
Here you can learn how set up mousestop event.
EDIT:
Making custom html elements may not be that strait forward in IE (who would have thought?). Check out more here.
I don't have any code for you, but perhaps this may be of a little help:
- When cursor is Idle, get coordinates
- Search for elements within the page at the above coordinate
- Use something like
var s = getElementById('ElementIDFoundinStepAbove').innerHTML;
That seems like a fairly logical approach, however, I don't know if this is at all possible.
Edit:
I have just found this post on S/O:
2444430
I hope this helps.
:)
Jason
精彩评论