Maison >interface Web >js tutoriel >Comment obtenir le mot sous le curseur de la souris avec JavaScript ?

Comment obtenir le mot sous le curseur de la souris avec JavaScript ?

Patricia Arquette
Patricia Arquetteoriginal
2024-10-26 07:06:03426parcourir

How to Get the Word Under the Mouse Cursor with JavaScript?

Comment récupérer le mot sous le curseur avec JavaScript

Déterminer le mot survolé par le curseur de la souris est une tâche essentielle pour le texte -applications basées. Supposons que vous ayez une page HTML avec un paragraphe de texte :

<code class="html"><p> some long text </p></code>

Comment identifier que le curseur est positionné au-dessus du mot « texte » ? Cet article présente une solution spécifiquement adaptée à Chrome (et potentiellement à Firefox).

Implémentation de JavaScript :

<code class="javascript">function getWordAtPoint(elem, x, y) {
  if (elem.nodeType == elem.TEXT_NODE) {
    // Create a range and position it within the element's text content
    var range = elem.ownerDocument.createRange();
    range.selectNodeContents(elem);

    // Initialize position variables
    var currentPos = 0;
    var endPos = range.endOffset;

    // Iterate through the text content
    while (currentPos + 1 < endPos) {
      // Update the range to select a single character
      range.setStart(elem, currentPos);
      range.setEnd(elem, currentPos + 1);

      // Check if the character's bounding rectangle contains the cursor position
      if (
        range.getBoundingClientRect().left <= x &&
        range.getBoundingClientRect().right >= x &&
        range.getBoundingClientRect().top <= y &&
        range.getBoundingClientRect().bottom >= y
      ) {
        // Expand the range to select the word
        range.expand("word");
        var ret = range.toString();
        range.detach();
        return ret;
      }

      // Advance the current position
      currentPos += 1;
    }
  } else {
    // For elements with child nodes (e.g., <p>, <div>), iterate through their children
    for (var i = 0; i < elem.childNodes.length; i++) {
      // Create a range and position it within the child node's text content
      var range = elem.childNodes[i].ownerDocument.createRange();
      range.selectNodeContents(elem.childNodes[i]);

      // Check if the child node's bounding rectangle contains the cursor position
      if (
        range.getBoundingClientRect().left <= x &&
        range.getBoundingClientRect().right >= x &&
        range.getBoundingClientRect().top <= y &&
        range.getBoundingClientRect().bottom >= y
      ) {
        // Recursively call getWordAtPoint on the child node
        range.detach();
        return getWordAtPoint(elem.childNodes[i], x, y);
      } else {
        range.detach();
      }
    }
  }

  return null;
}</code>

Utilisation :

Dans le gestionnaire d'événements de votre événement mousemove, vous pouvez utiliser la fonction getWordAtPoint() comme suit :

<code class="javascript">getWordAtPoint(e.target, e.x, e.y);</code>

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn