Heim >Web-Frontend >js-Tutorial >Wie implementiert man dynamisch maximale Längenbeschränkungen für TextAreas?

Wie implementiert man dynamisch maximale Längenbeschränkungen für TextAreas?

Mary-Kate Olsen
Mary-Kate OlsenOriginal
2024-10-20 18:25:31685Durchsuche

How to Dynamically Implement Maximum Length Restrictions on TextAreas?

Dynamisches Festlegen der maximalen Länge für Textbereiche

Die Durchsetzung von Zeichenbeschränkungen für Textbereiche ist wichtig, um die Datenintegrität sicherzustellen und Benutzereingabefehler zu verhindern. Während HTML das Attribut „maxlength“ für Eingabefelder bietet, wird es für Textbereiche nicht direkt unterstützt.

Eine einfache Lösung besteht darin, Ereignishandler wie „onKeyPress“ und „onKeyUp“ zu verwenden, um Benutzereingaben zu überwachen und einzuschränken. Dieser Ansatz erfordert jedoch eine manuelle Implementierung für jeden Textbereich.

Hier ist eine elegante JavaScript-Lösung, die diesen Prozess automatisiert und jedem Textbereich dynamisch „maxlength“ auferlegt:

<code class="javascript">window.onload = function() {
  var txts = document.getElementsByTagName('TEXTAREA');

  for(var i = 0, l = txts.length; i < l; i++) {
    if(/^[0-9]+$/.test(txts[i].getAttribute("maxlength"))) {
      var func = function() {
        var len = parseInt(this.getAttribute("maxlength"), 10);

        if(this.value.length > len) {
          alert('Maximum length exceeded: ' + len);
          this.value = this.value.substr(0, len);
          return false;
        }
      }

      txts[i].onkeyup = func;
      txts[i].onblur = func;
    }
  };
}</code>

So funktioniert es:

  • Das Skript beginnt damit, alle Textbereiche auf der Seite mit „getElementsByTagName“ abzurufen.
  • Es durchläuft jeden Textbereich und prüft, ob ein vorhanden ist 'maxlength'-Attribut mit einem numerischen Wert.
  • Wenn diese Bedingung erfüllt ist, wird den Ereignishandlern 'onkeyup' und 'onblur' des Textbereichs eine Funktion zugewiesen.
  • Die Funktion ruft ab das Attribut „maxlength“ und vergleicht es mit der aktuellen Textlänge.
  • Wenn die Textlänge das Maximum überschreitet, wird eine Warnmeldung angezeigt, der Text wird abgeschnitten und das Ereignis verhindert.

Durch die Verwendung dieses Skripts können Entwickler mühelos „maxlength“ für jeden Textbereich auf ihren Webseiten erzwingen, ohne dass eine manuelle Ereignisbehandlung erforderlich ist.

Das obige ist der detaillierte Inhalt vonWie implementiert man dynamisch maximale Längenbeschränkungen für TextAreas?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn