扫二维码与项目经理沟通
我们在微信上24小时期待你的声音
解答本文疑问/技术咨询/运营咨询/技术建议/互联网交流
focus是获得焦点事件。
创新互联成立与2013年,先为南安等服务建站,南安等地企业,进行企业商务咨询服务。为南安企业网站制作PC+手机+微官网三网同步一站式服务解决您的所有建站问题。
当一个文本框获得焦点时,它里面的文本就像“好123”网站上的百度搜索输入框那样全部被自动选中,这样的操作可以利用onfocus来实现。
以下的文本框,当鼠标指针移过去时,里面的文字全部被选中:
请输入网址
这是怎么做的呢?看以下代码及解释:
input type="text"name="url" value="" size="30"onmousemove="this.focus();this.select();"
代码里,input标签内嵌入了onmousemove(鼠标指针经过)事件的JS语句,其等号后面的this.focus()意为其自身获得焦点;获得焦点的标志是该文本框内将出现输入光标,但要让其内的文字全部被选中,我们还得用上this.select()语句,它的意思就是选中全部文本框里的文字。
焦点作为javascript中的一个重要功能,基本上和页面交互都离不开焦点。但却少有人对焦点管理系统地做总结归纳。本文就javascript中的焦点管理作详细介绍
1、焦点元素
默认情况下,只有表单元素可以获得焦点。因为只有表单元素可以交互
input type="text" value="223"
让非表单元素获得焦点也是有办法的,先将tabIndex属性设置为-1,再调用focus()方法
div id="test" style="height:30px;width:100px;background:lightgreen"div/div
button id="btn"div元素获得焦点/button
script
btn.onclick = function(){
test.tabIndex = -1;
test.focus();
}
test.onfocus = function(){
this.style.background = 'pink';
}
/script
2、activeElement
document.activeElement属性用于管理DOM焦点,保存着当前获得焦点的元素
注:该属性IE浏览器不支持
div id="test" style="height:30px;width:100px;background:lightgreen"div/div
button id="btn"div元素获得焦点/button
script
console.log(document.activeElement);//body
btn.onclick = function(){
console.log(document.activeElement);//button
test.tabIndex = -1;
test.focus();
console.log(document.activeElement);//div
}
/script
3、获得焦点
元素获得焦点的方式有4种,包括页面加载、用户输入(按tab键)、focus()方法和autofocus属性
【1】页面加载
默认情况下,文档刚刚加载完成时,document.activeElement中保存的是body元素的引用。文档加载期间,document.activeElement的值为null
【2】用户输入(按tab键)
用户通常可以使用tab键移动焦点,使用空格键激活焦点。比如,如果焦点在一个链接上,此时按一下空格键,就会跳转到该链接
说到tab键,就不能不提到tabindex属性。tabindex属性用来指定当前HTML元素节点是否被tab键遍历,以及遍历的优先级
1、如果tabindex=-1,tab键跳过当前元素
2、如果tabindex=0,表示tab键将遍历当前元素。如果一个元素没有设置tabindex,默认值就是0
3、如果tabindex大于0,表示tab键优先遍历。值越大,就表示优先级越小
【3】focus()
focus()方法用于将浏览器的焦点设置到表单字段,即激活表单字段,使其可以响应键盘事件
注:前面介绍过,若非表单元素,设置为tabIndex为-1,也可以获取焦点
【4】autofocus
HTML5表单字段新增了autofocus属性,只要设置这个属性,不用javascript就能自动把焦点移动到相应字段
[注意]该属性只能用于表单元素,普通元素即使设置tabIndex="-1"也不生效
【5】hasFocus()
document.hasFocus()方法返回一个布尔值,表示当前文档之中是否有元素被激活或获得焦点。通过检测文档是否获得了焦点,可以知道是不是正在与页面交互
4、失去焦点
如果使用javascript使元素失去焦点,那么就要使用blur()方法
blur()方法的作用是从元素中移走焦点。在调用blur()方法时,并不会把焦点转移到某个特定的元素上;仅仅是将焦点从调用这个方法的元素上面移走而已
5、焦点事件
焦点事件会在页面获得或失去焦点时触发。利用这些事件并与document.hasFocus()方法及 document.activeElement属性配合,可以知晓用户在页面上的行踪
【1】焦点事件共包括下面4个
blur
blur事件在元素失去焦点时触发。这个事件不会冒泡
focus
focus事件在元素获得焦点时触发。这个事件不会冒泡
focusin
focusin事件在元素获得焦点时触发。这个事件与focus事件等价,但它冒泡
focusout
focusour事件在元素失去焦点时触发。这个事件与blur事件等价,但它冒泡
[注意] 关于focusin和focusout事件,除了IE浏览器支持DOM0级事件处理程序,其他浏览器都只支持DOM2级事件处理程序
//聚焦的时候执行它
function focusToDo(Control,txt)
{
if(Control.value == txt)
{
//方法可以进入这里,但是下面这一句无法执行
setCaretPosition(Control,0);
}
}
上边这段代码里setCaretPosition(Control,0);的Control是来自focusToDo(Control,txt)函数的第一个参数。
你需要看一下,你传入的参数Control是一个正确的节点吗?
还是你根本没有传参?
首先你的 function要写在
script language="javascript"
/script中间
然后你的函数要打括号function jujiao()
然后你的onclick事件要onclick="jujiao();"
这样写
最后
给你的这个例子
script language="javascript"
function check() {
var c = document.getElementById("uname").value;
if(c.length 6) {
window.alert("用户名必需有6位字符");
document.getElementById("uname").focus();
return false;
}
}
/script
用户名: input type="text" id="uname" maxlength="15"/
input type="button" onclick="check()" value="提交"/
你会发现当条件不成立的时候光标会一闪一闪的,这就是focus焦点的效果
我刚才测试了,除了刚进页面的时候聚焦光标是不在文字后面的其他的都在。我写了这样的代码,转换一下,获取下值,然后再赋值,光标自然就到文字后面了
input type="text" value="一个"
button点击/button
script type="text/javascript"
$("button").click(function () {
var v = $("input").val();
$("input").focus().val(v);
})
/script
我们在微信上24小时期待你的声音
解答本文疑问/技术咨询/运营咨询/技术建议/互联网交流