Heim >Web-Frontend >js-Tutorial >Eine einfache Möglichkeit, den Fokus in js auf die letzte Position zu verschieben
Wenn das Eingabefeld (Eingabe-/Textbereich) den Fokus erhält, verschieben Sie den Fokus an das Ende. In einigen Fällen ist die Benutzererfahrung gut. Die meisten Methoden im Internet gelten für IE-Browser.
Der Code lautet wie folgt:
var el = document.getElementById('txtArticle'); var range = el.createTextRange(); range.moveStart('character', el.value.length); range.collapse(false); range.select();
Tatsächlich können Sie die Zeile „moveStart“ löschen, da die Methode „createTextRange“ die Zeile erstellt Bereich, es verwendet die Collapse-Methode und die Parameter. Wenn es falsch ist, kann es an das Ende verschoben werden. collapse(true) bewegt den Cursor an den Anfang des Bereichs, Collapse(false) bewegt den Cursor an das Ende des Bereichs. Standardbrowser wie Firefox können die setSelectionRange-Methode von w3c verwenden.
Der Code lautet wie folgt:
var range, el = document.getElementById('txtPhone'); if (el.setSelectionRange) { el.focus(); el.setSelectionRange(el.value.length, el.value.length) } else { range = el.createTextRange(); range.collapse(false); range.select(); }
Beachten Sie, dass die setSelectionRange-Methode nur für Eingabe-/Textbereichselemente gilt. Der Fokus anderer nicht nativer bearbeitbarer Elemente kann auf die Minimierungsmethode des Auswahlobjekts verschoben werden,
Zum Beispiel:
var sel, el = document.getElementById('hint'); sel = window.getSelection(); sel.collapse(el, 1); el.focus();