There are two parts to your question.
你的问题有两个部分。
1) How to focus an input on page load?
1)如何将输入集中在页面加载上?
You can just add the autofocus
attribute to the input.
只需将自动聚焦属性添加到输入即可。
<input id="myinputbox" type="text" autofocus>
However, this might not be supported in all browsers, so we can use javascript.
然而,并不是所有的浏览器都支持这一点,所以我们可以使用javascrip。
window.onload = function() {
var input = document.getElementById("myinputbox").focus();
}
2) How to place cursor at the end of the input text?
2)如何将光标放在输入文本的末尾?
Here's a non-jQuery solution with some borrowed code from another SO answer.
下面是一个非jQuery解决方案,其中包含一些借用自另一个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();
}
Here's an example of how I would accomplish this with jQuery.
以下是我将如何使用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>
Just a heads up - you can now do this with HTML5 without JavaScript for browsers that support it:
提醒一下--您现在可以在支持HTML5的浏览器上使用HTML5实现这一点,而无需使用Java脚本:
<input type="text" autofocus>
You probably want to start with this and build onto it with JavaScript to provide a fallback for older browsers.
您可能希望从这一点开始,并使用JavaScript构建它,以便为较旧的浏览器提供后备。
$(document).ready(function() {
$('#id').focus();
});
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">
A portable way of doing this is using a custom function (to handle browser differences) like this one.
实现这一点的一种可移植方法是使用如下所示的定制函数(以处理浏览器差异)。
Then setup a handler for the onload
at the end of your <body>
tag, as jessegavin wrote:
然后在标记的末尾为onLoad设置一个处理程序,如jesSegavin所写:
window.onload = function() {
document.getElementById("myinputbox").focus();
}
very simple one line solution:
非常简单的一行解决方案:
<body onLoad="document.getElementById('myinputbox').focus();">
Working fine...
工作很好..。
window.onload = function() {
var input = document.getElementById("myinputbox").focus();
}
Try:
尝试:
Javascript Pure:
纯Java脚本:
[elem][n].style.visibility='visible';
[elem][n].focus();
Jquery:
JQuery:
[elem].filter(':visible').focus();
This is what works fine for me:
这就是对我来说很好的方法:
<form name="f" action="/search">
<input name="q" onfocus="fff=1" />
</form>
fff will be a global variable which name is absolutely irrelevant and which aim will be to stop the generic onload event to force focus in that input.
Fff将是一个全局变量,其名称完全无关,其目的将是停止通用onLoad事件以强制在该输入中聚焦。
<body onload="if(!this.fff)document.f.q.focus();">
<!-- ... the rest of the page ... -->
</body>
From: http://webreflection.blogspot.com.br/2009/06/inputfocus-something-really-annoying.html
出发地:http://webreflection.blogspot.com.br/2009/06/inputfocus-something-really-annoying.html
If you can't add to the BODY tag for some reason, you can add this AFTER the Form:
如果由于某些原因不能添加到Body标记,可以在表单后添加以下内容:
<SCRIPT type="text/javascript">
document.yourFormName.yourFieldName.focus();
</SCRIPT>
Add this to the top of your js
将此添加到js的顶部
var input = $('#myinputbox');
input.focus();
Or to html
或设置为html
<script>
var input = $('#myinputbox');
input.focus();
</script>
Just do it!
就这么做!
window.onload = function() {
setTimeout(function () {
document.getElementById("input-box-id").focus();
document.getElementById("input-box-id").click();
}, 1000);
}
更多回答
The first code block suggested actually places the cursor at the end of the existing value as well, it works good. I apreciate your help.
建议的第一个代码块实际上也将光标放在现有值的末尾,效果很好。我非常感谢你的帮助。
The Javascript version is very good, works flawless for iframe with autofocus issues. Also lightweight and compact. +1 as it helped me.
JavaScript版本非常好,对于具有自动聚焦问题的iframe来说完美无瑕。同样轻巧紧凑。+1因为它帮助了我。
Nice to know that, does this already moves the cursor to the last position in the input field?
很高兴知道这一点,这是否已经将光标移动到输入字段的最后位置?
I don't think that @Codex73 is trying to accomplish what the placeholder attribute in HTML5 does. It sounds like he wants the cursor to be automatically positioned at the end of whatever value is currently in the input.
我不认为@Codex73试图完成HTML5中的占位符属性所做的事情。听起来他想让光标自动定位在当前输入的任何值的末尾。
You're right, this isn't a complete solution. But this does solve a couple of things (onload autofocus and placeholder text).
你说得对,这不是一个完整的解决方案。但这确实解决了一些问题(加载自动对焦和占位符文本)。
Note that as of 1/2019, Safari on iOS does not support this: caniuse.com/#feat=autofocus
请注意,从2019年1月1日起,iOS上的Safari不支持此功能:caniuse.com/#feat=AutoFocus
This requires jQuery.
这需要jQuery。
Yeah you need to include jQuery libs :)
是的,您需要包括jQuery库:)
classic stackoverflow :)
经典堆栈溢出:)
我是一名优秀的程序员,十分优秀!