Caixa de entrada de foco na carga


95

Como o cursor pode ser focalizado em uma caixa de entrada específica no carregamento da página?

É possível reter também o valor do texto inicial e colocar o cursor no final da entrada?

<input type="text"  size="25" id="myinputbox" class="input-text" name="input2" value = "initial text" />

Respostas:


170

A sua pergunta tem duas partes.

1) Como concentrar uma entrada no carregamento da página?

Você pode simplesmente adicionar o autofocusatributo à entrada.

<input id="myinputbox" type="text" autofocus>

No entanto, isso pode não ser compatível com todos os navegadores, então podemos usar javascript.

window.onload = function() {
  var input = document.getElementById("myinputbox").focus();
}

2) Como colocar o cursor no final do texto de entrada?

Aqui está uma solução não jQuery com algum código emprestado de outra resposta do SO .

function placeCursorAtEnd() {
  if (this.setSelectionRange) {
    // Double the length because Opera is inconsistent about 
    // whether a carriage return is one character or two.
    var len = this.value.length * 2;
    this.setSelectionRange(len, len);
  } else {
    // This might work for browsers without setSelectionRange support.
    this.value = this.value;
  }

  if (this.nodeName === "TEXTAREA") {
    // This will scroll a textarea to the bottom if needed
    this.scrollTop = 999999;
  }
};

window.onload = function() {
  var input = document.getElementById("myinputbox");

  if (obj.addEventListener) {
    obj.addEventListener("focus", placeCursorAtEnd, false);
  } else if (obj.attachEvent) {
    obj.attachEvent('onfocus', placeCursorAtEnd);
  }

  input.focus();
}

Aqui está um exemplo de como eu faria isso com jQuery.

<input type="text" autofocus>

<script>
$(function() {
  $("[autofocus]").on("focus", function() {
    if (this.setSelectionRange) {
      var len = this.value.length * 2;
      this.setSelectionRange(len, len);
    } else {
      this.value = this.value;
    }
    this.scrollTop = 999999;
  }).focus();
});
</script>

3
O primeiro bloco de código sugerido também coloca o cursor no final do valor existente, funciona bem. Agradeço sua ajuda.
Codex73 de

46

Apenas um aviso - agora você pode fazer isso com HTML5 sem JavaScript para navegadores que o suportam:

<input type="text" autofocus>

Você provavelmente deseja começar com isso e construir com JavaScript para fornecer um fallback para navegadores mais antigos.


É bom saber disso, isso já move o cursor para a última posição no campo de entrada?
Camilo Díaz Repka

1
Não acho que @ Codex73 esteja tentando realizar o que o atributo placeholder no HTML5 faz. Parece que ele deseja que o cursor seja posicionado automaticamente no final de qualquer valor que esteja atualmente na entrada.
jessegavin

2
Você está certo, esta não é uma solução completa. Mas isso resolve algumas coisas (autofoco ao carregar e texto de espaço reservado).
David Calhoun

Observe que a partir de 1/2019, o Safari no iOS não oferece suporte para: caniuse.com/#feat=autofocus
sporker


3
function focusOnMyInputBox(){                                 
    document.getElementById("myinputbox").focus();
}

<body onLoad="focusOnMyInputBox();">

<input type="text"  size="25" id="myinputbox" class="input-text" name="input2" onfocus="this.value = this.value;" value = "initial text">

2

Uma maneira portátil de fazer isso é usar uma função personalizada (para lidar com as diferenças do navegador) como esta .

Em seguida, configure um manipulador para o onloadno final de sua <body>tag, como escreveu jessegavin:

window.onload = function() {
  document.getElementById("myinputbox").focus();
}

1

Trabalhando bem...

window.onload = function() {
  var input = document.getElementById("myinputbox").focus();
}

1

solução muito simples de uma linha:

<body onLoad="document.getElementById('myinputbox').focus();">


0

Se você não puder adicionar a tag BODY por algum motivo, você pode adicionar isto DEPOIS do formulário:

<SCRIPT type="text/javascript">
    document.yourFormName.yourFieldName.focus();
</SCRIPT>

0

Experimentar:

Javascript Pure:

[elem][n].style.visibility='visible';
[elem][n].focus();

Jquery:

[elem].filter(':visible').focus();

0

Adicione isso ao topo do seu js

var input = $('#myinputbox');

input.focus();

Ou para html

<script>
    var input = $('#myinputbox');

    input.focus();
</script>
Ao utilizar nosso site, você reconhece que leu e compreendeu nossa Política de Cookies e nossa Política de Privacidade.
Licensed under cc by-sa 3.0 with attribution required.