Maison > interface Web > js tutoriel > Comment définir la position du curseur dans les zones de texte à l'aide de jQuery ?

Comment définir la position du curseur dans les zones de texte à l'aide de jQuery ?

DDD
Libérer: 2024-12-08 14:14:10
original
798 Les gens l'ont consulté

How to Set the Cursor Position in Text Areas Using jQuery?

Définition de la position du curseur dans les zones de texte avec jQuery

Lorsque vous souhaitez que les utilisateurs se concentrent sur une partie spécifique d'un champ de texte, vous devrez peut-être positionner le curseur à un certain décalage à l'intérieur du champ. Pour y parvenir en utilisant jQuery, vous pouvez implémenter une fonction setCursorPosition.

$.fn.setCursorPosition = function(pos) {
  if (this.setSelectionRange) {
    this.setSelectionRange(pos, pos);
  } else if (this.createTextRange) {
    var range = this.createTextRange();
    range.collapse(true);
    if (pos < 0) {
      pos = $(this).val().length + pos;
    }
    range.moveEnd("character", pos);
    range.moveStart("character", pos);
    range.select();
  }
};
Copier après la connexion

Avec cette fonction en place, vous pouvez définir la position du curseur en l'appelant avec le décalage souhaité :

$("#input").focus(function() {
  $(this).setCursorPosition(4);
});
Copier après la connexion

Dans cet exemple, lorsque le champ #input reçoit le focus, le curseur sera positionné après le quatrième caractère (en comptant à partir de 0).

Une approche alternative est pour utiliser la fonction selectRange fournie dans la réponse acceptée :

$.fn.selectRange = function(start, end) {
  if (end === undefined) {
    end = start;
  }
  return this.each(function() {
    if ("selectionStart" in this) {
      this.selectionStart = start;
      this.selectionEnd = end;
    } else if (this.setSelectionRange) {
      this.setSelectionRange(start, end);
    } else if (this.createTextRange) {
      var range = this.createTextRange();
      range.collapse(true);
      range.moveEnd("character", end);
      range.moveStart("character", start);
      range.select();
    }
  });
};
Copier après la connexion

À l'aide de cette fonction, vous pouvez positionner le curseur et sélectionner une plage de texte :

$("#elem").selectRange(3, 5); // select a range of text
$("#elem").selectRange(3); // set cursor position
Copier après la connexion

Ces solutions proposent diverses méthodes pour définir la position du curseur et manipuler la sélection de texte dans les champs de texte à l'aide de jQuery.

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!

source:php.cn
Déclaration de ce site Web
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
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal