Maison >interface Web >tutoriel CSS >Comment Prototype.js peut-il dimensionner automatiquement une zone de texte verticalement tout en conservant une largeur fixe ?

Comment Prototype.js peut-il dimensionner automatiquement une zone de texte verticalement tout en conservant une largeur fixe ?

Linda Hamilton
Linda Hamiltonoriginal
2024-12-26 20:13:14798parcourir

How Can Prototype.js Autosize a Textarea Vertically While Maintaining Fixed Width?

Autodimensionnement d'une zone de texte avec un prototype pour une interface utilisateur raffinée

L'amélioration de l'expérience utilisateur implique souvent de se concentrer sur des détails subtils mais percutants. L'un de ces aspects est le redimensionnement automatique des zones de texte, leur donnant la possibilité de s'adapter au contenu qu'elles contiennent, garantissant ainsi une utilisation optimale de l'espace et une lisibilité.

Dans ce cas, l'utilisateur vise à redimensionner automatiquement une zone de texte verticalement tout en conservant une largeur fixe. . Bien que le redimensionnement horizontal puisse être difficile en raison du renvoi à la ligne et des longueurs de ligne variables, le redimensionnement vertical est une solution viable et conviviale.

Pour mettre en œuvre ce comportement de dimensionnement automatique, ils ont demandé conseil et trouvé une solution pratique en utilisant Prototype, un bibliothèque JavaScript populaire. L'extrait de code fourni présente l'approche :

resizeIt = function() {
  var str = $('text-area').value;
  var cols = $('text-area').cols;

  var linecount = 0;
  $A(str.split("\n")).each( function(l) {
      linecount += Math.ceil( l.length / cols ); // Take into account long lines
  })
  $('text-area').rows = linecount + 1;
};

Event.observe('text-area', 'keydown', resizeIt );

resizeIt(); //Initial on load

Ce code parcourt chaque ligne de contenu dans la zone de texte, en tenant compte des sauts de ligne et des lignes longues, et calcule le nombre de lignes nécessaire pour un ajustement parfait. En attachant un écouteur d'événement pour capturer les frappes au clavier, la zone de texte est continuellement redimensionnée en réponse aux modifications du texte, présentant ainsi une expérience adaptative et centrée sur l'utilisateur.

L'adoption de cette stratégie peut rationaliser les interactions des utilisateurs, réduisant ainsi le besoin de défilement inutile et garantissant une interface transparente et visuellement attrayante pour la saisie de texte.

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