焦点作为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级事件处理程序。
代码如下:
<input name="pwuser" type="text" id="pwuser" class="input" value="楼盘账号" onBlur="if(this.value=='') this.value='楼盘账号';" onFocus="if(this.value=='楼盘账号') this.value='';" /> 。
<input name="pwpwd" type="password" class="input1" value="******" onBlur="if(this.value=='') this.value='******';" onFocus="if(this.value=='******') this.value='';"> 。
jquery实现方法
对于元素的焦点事件,我们可以使用jQuery的焦点函数focus(),blur()。
focus():得到焦点时使用,和javascript中的onfocus使用方法相同。
如:
代码如下:
$("p").focus(); 或$("p").focus(fn) 。
blur():和onblur一样。
如:
代码如下:
$("p").blur(); 或$("p").blur(fn) 。
实例
代码如下:
<form>
<label for="searchKey" id="lbSearch">搜神马?</label> 这里label覆盖在文本框上,可以更好的控制样式 。
<input id="searchKey" type="text" /> 。
<input type="submit" value="搜索" /> 。
</form>
jquery代码
代码如下:
$(function() { 。
$('#searchKey').focus(function() { 。
$('#lbSearch').text(''); 。
});
$('#searchKey').blur(function() { 。
var str = $(this).val(); 。
str = $.trim(str); 。
if(str == '')
$('#lbSearch').text('搜神马?'); 。
});
})
用自带的focus()就可以了。
利用js中<input/>实现文本框默认获取输入焦点完整代码实现如下:
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=ISO-8859-1">。
<title>Insert title here</title>。
<script type="text/javascript"> 。
//输入框获取鼠标焦点 。
function autoFocus(){。
var pFocus = document.getElementById("password");。
pFocus.focus();。
pFocus.select();。
}
</script>。
</head>
<body onload="autoFocus()">。
<div id="loginform">。
<h1 style="font-size:1.5em;padding:20px;">输入密码</h1>。
<form action="${pageContext.request.contextPath}/" method="post">。
<input id="password" type="password" name="password">。
<input type="submit" value="提交">。
</form>
</div>
</body>
</html>
扩展资料:
JavaScript 使我们有能力创建动态页面。事件是可以被 JavaScript 侦测到的行为。 网页中的每个元素都可以产生某些可以触发JavaScript函数的事件。比方说,我们可以在用户点击某按钮时产生一个 onClick 事件来触发某个函数。事件在 HTML 页面中定义 。
参考资料:
JavaScript官方API接口-:focus。
百度百科-JavaScript。
W3cschool-获得字段焦点。
让输入框获取焦点:
方法1:<body onload="document.getElementById('inputId').focus()">。
方法2:
function init(){。
document.getElementById("inputId").focus();。
}
例如:
<body onload="document.getElementById('test').focus()">。
我要获取焦点:<input type="text" name="test" id="test">。
</body>
需要准备的材料分别是:电脑、html编辑器、浏览器。
1、首先,打开html编辑器,新建html文件,例如:index.html。
2、在index.html的<script>标签中,输入js代码:
$('body').append(document.activeElement.id == "a" ? 'true': 'false');。
$('#a').focus(function () {。
$('body').append(document.activeElement.id == "a" ? 'true': 'false');。
});
3、浏览器运行index.html页面,此时会发现false代表没有聚焦,点击聚焦后发现打印了true。