Primefaces inputtext Fokus am Ende des Textes

Hier ein snippet von meiner JSF:

<p:tabView id="tabView" var="tab" value="#{data.tabs}" widgetVar="tabViewWidget"
                activeIndex="#{data.newActiveTabIndex}">

                <p:ajax event="tabClose" listener="#{logic.closeTab}" />

                <p:tab title="#{tab.content.title != null ? tab.content.title : '&amp;lt;new&amp;gt;'}"
                    closable="#{tab.isClosable and data.tabs.size() > 2}">
                    <h:outputText value="#{tab.id} Test" />

                    <p:focus rendered="#{data.componentIdToFocus != null}" for="#{data.componentIdToFocus}" />

                    <p:inputText id="test" value="#{tab.content.title}">
                        <p:ajax event="keyup" listener="#{logic.setFocusingComponent}" update=":form:tabView" />
                    </p:inputText>
                </p:tab>

            </p:tabView>

Die Absicht ist, dass es ein textfield in jedem Register, die updates der Titel der Registerkarte, während Sie schreiben.
Die angegebenen snippet funktioniert, außer, dass p:Fokus-setzt den cursor an den Anfang des Textes, ist schon geschrieben. Ich möchte den cursor an das Ende des Textes bereits geschrieben. Damit ein Benutzer Daten eingeben können, und während er/Sie die Eingabe der Titel passt sich automatisch an.

Ich hoffe, mein Fall ist klar.
Hat jemand eine Lösung dafür?

Beste Grüße,
Florian

  • Geben Sie eine id, um Ihre Registerkarte, und ändern Sie update-Teil des ajax ":form:tabView:tabIndex". Diese sollten nur aktualisieren Sie die Registerkarte Titel und Sie würden nicht verlieren den Fokus für den text.
Schreibe einen Kommentar