详细总结Javascript中的焦点管理


Posted in Javascript onSeptember 17, 2016

焦点元素

到底哪些元素可以获得焦点呢?默认情况下,只有表单元素可以获得焦点。因为只有表单元素可以交互

<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>

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>

获得焦点

元素获得焦点的方式有4种,包括页面加载、用户输入(按tab键)、focus()方法和autofocus属性

【1】页面加载

默认情况下,文档刚刚加载完成时,document.activeElement中保存的是body元素的引用。文档加载期间,document.activeElement的值为null

<script>
console.log(document.activeElement);//null
</script>
<body>
<script>
console.log(document.activeElement);//<body>
</script>
</body>

【2】用户输入(按tab键)

用户通常可以使用tab键移动焦点,使用空格键激活焦点。比如,如果焦点在一个链接上,此时按一下空格键,就会跳转到该链接

说到tab键,就不能不提到tabindex属性。tabindex属性用来指定当前HTML元素节点是否被tab键遍历,以及遍历的优先级

1、如果tabindex=-1,tab键跳过当前元素

2、如果tabindex=0,表示tab键将遍历当前元素。如果一个元素没有设置tabindex,默认值就是0

3、如果tabindex大于0,表示tab键优先遍历。值越大,就表示优先级越小

下列代码中,使用tab键时,button获得焦点的顺序是2、5、1、3

<div id="box">
 <button tabindex= "3">1</button>
 <button tabindex= "1">2</button>
 <button tabindex= "0">3</button>
 <button tabindex= "-1">4</button>
 <button tabindex= "2">5</button> 
</div>
<script>
box.onkeyup = function(){
 document.activeElement.style.background = 'pink';
}
</script>

【3】focus()

focus()方法用于将浏览器的焦点设置到表单字段,即激活表单字段,使其可以响应键盘事件

[注意]前面介绍过,若非表单元素,设置为tabIndex为-1,也可以获取焦点

<span id="test1" style="height:30px;width:100px;">span</span>
<input id="test2" value="input">
<button id="btn1">span元素获得焦点</button>
<button id="btn2">input元素获得焦点</button>
<script>
btn1.onclick = function(){test1.tabIndex=-1;test1.focus();}
btn2.onclick = function(){test2.focus();}
</script>

【4】autofocus

HTML5表单字段新增了一个autofocus属性,只要设置这个属性, 不用javascript就能自动把焦点移动到相应字段

[注意]该属性只能用于表单元素,普通元素即使设置tabIndex=”-1″也不生效

<input autofocus value="abc">

hasFocus()

document.hasFocus()方法返回一个布尔值,表示当前文档之中是否有元素被激活或获得焦点。通过检测文档是否获得了焦点,可以知道是不是正在与页面交互

console.log(document.hasFocus());//true
//在两秒钟内点击其他标签页,使焦点离开当前页面
setTimeout(function(){
 console.log(document.hasFocus());//false
},2000);

失去焦点

如果使用javascript来使元素失去焦点,那么就要使用blur()方法

blur()方法的作用是从元素中移走焦点。在调用blur()方法时,并不会把焦点转移到某个特定的元素上;仅仅是将焦点从调用这个方法的元素上面移走而已

<input id="test" type="text" value="123">
<button id="btn1">input元素获得焦点</button>
<button id="btn2">input元素失去焦点</button>
<script>
btn1.onclick = function(){test.focus();}
btn2.onclick = function(){test.blur();}
</script>

焦点事件

焦点事件会在页面获得或失去焦点时触发。利用这些事件并与document.hasFocus()方法及 document.activeElement属性配合,可以知晓用户在页面上的行踪

焦点事件共包括下面4个

1、blur

blur事件在元素失去焦点时触发。这个事件不会冒泡

2、focus

focus事件在元素获得焦点时触发。这个事件不会冒泡

3、focusin

focusin事件在元素获得焦点时触发。这个事件与focus事件等价,但它冒泡

4、focusout

focusour事件在元素失去焦点时触发。这个事件与blur事件等价,但它冒泡

[注意]关于focusin和focusout事件,除了IE浏览器支持DOM0级事件处理程序,其他浏览器都只支持DOM2级事件处理程序

<div id="box"style="display:inline-block;padding:25px;background-color:lightgreen;">
 <div id="boxIn" style="height: 50px;width: 50px;background-color:pink;">123</div>
</div>
<button id="btn1">内容为123的div元素获取焦点</button>
<button id="btn2">内容为123的div元素失去焦点</button>
<button id="reset">还原</button>
<script>
reset.onclick = function(){history.go();}
//focus()方法
btn1.onclick = function(){
 boxIn.tabIndex= -1;
 boxIn.focus();
}
//blur()方法
btn2.onclick = function(){
 boxIn.blur();
}
//focusin事件
if(boxIn.addEventListener){
 boxIn.addEventListener('focusin',handler) 
}else{
 boxIn.onfocusin = handler;
}
function handler(){
 this.style.backgroundColor ='lightblue';
}
if(box.addEventListener){
 box.addEventListener('focusin',handler) 
}else{
 box.onfocusin = handler;
} 
//blur事件
function fnBlur(){
 this.style.backgroundColor = 'orange';
}
boxIn.onblur = fnBlur;
box.onblur = fnBlur;
</script>

由运行结果可知,focusin事件可冒泡;而blur事件不可冒泡 

焦点事件常用于表单展示及验证

比如,获取焦点时,修改背景颜色;失去焦点时,还原背景颜色并验证

<div id="box">
 <input id="input1" type="text" placeholder="只可以输入数字">
 <input id="input2" type="text" placeholder="只可以输入汉字"> 
 <span id="tips"></span>
</div>
<script>
if(box.addEventListener){
 box.addEventListener('focusin',fnIn);
 box.addEventListener('focusout',fnOut);
}else{
 box.onfocusin = fnIn;
 box.onfocusout = fnOut;
}
function fnIn(e){
 e = e || event;
 var target = e.target || e.srcElement;
 target.style.backgroundColor = 'lightgreen';
}
function fnOut(e){
 e = e || event;
 var target = e.target || e.srcElement;
 target.style.backgroundColor = 'initial';
 //如果是验证数字的文本框
 if(target === input1){
 if(!/^\d*$/.test(target.value.trim())){
 target.focus();
 tips.innerHTML = '只能输入数字,请重新输入'
 setTimeout(function(){
 tips.innerHTML = ''
 },500);
 }
 }
 //如果是验证汉字的文本框
 if(target === input2){
 if(!/^[\u4e00-\u9fa5]*$/.test(target.value.trim())){
 target.focus();
 tips.innerHTML = '只能输入汉字,请重新输入'
 setTimeout(function(){
 tips.innerHTML = ''
 },500);
 }
 } 
}
</script>

总结

以上就是为大家总结Javascript中焦点管理的全部内容,这篇文章介绍的很详细,对大家的学习和工作具有一定的参考借鉴价值,如果有疑问大家可以留言交流。

Javascript 相关文章推荐
JSON 和 JavaScript eval使用说明
Jun 13 Javascript
通过Javascript创建一个选择文件的对话框代码
Jun 16 Javascript
jQuery中index()方法用法实例
Dec 27 Javascript
jQuery双向列表选择器DIV模拟版
Nov 01 Javascript
JavaScript实现的浏览器下载文件的方法
Aug 09 Javascript
浅谈在Vue-cli里基于axios封装复用请求
Nov 06 Javascript
实现div内部滚动条滚动到底部和顶部的代码
Nov 15 Javascript
vue中阻止click事件冒泡,防止触发另一个事件的方法
Feb 08 Javascript
AngularJs1.x自定义指令独立作用域的函数传入参数方法
Oct 09 Javascript
JS实现音乐钢琴特效
Jan 06 Javascript
深入解读VUE中的异步渲染的实现
Jun 19 Javascript
JavaScript实现世界各地时间显示
Sep 07 Javascript
js变量提升深入理解
Sep 16 #Javascript
再谈javascript常见错误及解决方法
Sep 16 #Javascript
使用JQuery中的trim()方法去掉前后空格
Sep 16 #Javascript
浅谈jQuery效果函数
Sep 16 #Javascript
jQuery插件easyUI实现通过JS显示Dialog的方法
Sep 16 #Javascript
jQuery实现的右下角广告窗体跟随效果示例
Sep 16 #Javascript
jQuery实现磁力图片跟随效果完整示例
Sep 16 #Javascript
You might like
openflashchart 2.0 简单案例php版
2012/05/21 PHP
PHP中让curl支持sock5的代码实例
2015/01/21 PHP
Symfony学习十分钟入门经典教程
2016/02/03 PHP
thinkphp3.x连接mysql数据库的方法(具体操作步骤)
2016/05/19 PHP
PHP设计模式之建造者模式(Builder)原理与用法案例详解
2019/12/12 PHP
高性能WEB开发 flush让页面分块,逐步呈现 flush让页面分块,逐步呈现
2010/06/19 Javascript
javascript限制文本框只允许输入数字(曾经与现在的方法对比)
2013/01/18 Javascript
IE8中使用javascript动态加载CSS的解决方法
2014/06/17 Javascript
jquery访问ashx文件示例代码
2014/08/11 Javascript
js阻止事件追加的具体实现
2014/10/15 Javascript
JS+CSS实现的拖动分页效果实例
2015/05/11 Javascript
jQuery判断指定id的对象是否存在的方法
2015/05/22 Javascript
jquery实现图片放大镜功能
2015/11/23 Javascript
node.js实现端口转发
2016/04/14 Javascript
微信小程序 教程之wxapp视图容器 scroll-view
2016/10/19 Javascript
bootstrap中selectpicker下拉框使用方法实例
2018/03/22 Javascript
Vue中 v-if/v-show/插值表达式导致闪现的原因及解决办法
2018/10/12 Javascript
微信小程序实现提交input信息到后台的方法示例
2019/01/19 Javascript
vue 实现动态路由的方法
2020/07/06 Javascript
vue setInterval 定时器失效的解决方式
2020/07/30 Javascript
[02:25]DOTA2英雄基础教程 熊战士
2014/01/03 DOTA
Python3的urllib.parse常用函数小结(urlencode,quote,quote_plus,unquote,unquote_plus等)
2016/09/18 Python
安装python3的时候就是输入python3死活没有反应的解决方法
2018/01/24 Python
tensorflow入门:TFRecordDataset变长数据的batch读取详解
2020/01/20 Python
python闭包、深浅拷贝、垃圾回收、with语句知识点汇总
2020/03/11 Python
Python 如何展开嵌套的序列
2020/08/01 Python
如何使用Django Admin管理后台导入CSV
2020/11/06 Python
基于Modernizr 让网站进行优雅降级的分析
2013/04/21 HTML / CSS
Oral-B荷兰:牙医最推荐的品牌
2020/02/25 全球购物
Java的类可以定义为Protected或者Private得吗
2015/09/25 面试题
校园之星获奖感言
2014/01/29 职场文书
2014年开学第一课活动方案
2014/03/06 职场文书
大学生励志演讲稿
2014/04/25 职场文书
中学生运动会通讯稿大全
2014/09/18 职场文书
幼儿教师师德师风自我剖析材料
2014/09/29 职场文书
城镇居民医疗保险工作总结
2015/08/10 职场文书