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" />
Codex73
fonte

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>
Jessegavin
fonte
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.

David Calhoun
fonte
É 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
11
$(document).ready(function() {
    $('#id').focus();
});
Nasruddin
fonte
1
Isso requer jQuery.
Tom Pohl
1
Sim, você precisa incluir jQuery libs :)
Nasruddin
stackoverflow clássico :)
Florian Fida
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">
crnlx
fonte
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();
}
Camilo Díaz Repka
fonte
1

Trabalhando bem...

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

solução muito simples de uma linha:

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

Isso é o que funciona bem para mim:

<form name="f" action="/search">
    <input name="q" onfocus="fff=1" />
</form>

fff será uma variável global cujo nome é absolutamente irrelevante e cujo objetivo será interromper o evento onload genérico para forçar o foco nessa entrada.

<body onload="if(!this.fff)document.f.q.focus();">
    <!-- ... the rest of the page ... -->
</body>

De: http://webreflection.blogspot.com.br/2009/06/inputfocus-something-really-annoying.html

Roger
fonte
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>
Zardiw
fonte
0

Experimentar:

Javascript Pure:

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

Jquery:

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

Adicione isso ao topo do seu js

var input = $('#myinputbox');

input.focus();

Ou para html

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

    input.focus();
</script>
Marty
fonte