前言: 有时需要获取页面焦点在哪个元素上,通过焦点可以判断用户是否在操作页面等信息。以前不太方便,要自己记录,html5 增加了document.activeElement属性 可以获取到当前激活的焦点。
1、默认焦点在body页面加载后,document.activeElement是在body上: console.log(document.activeElement);// 控制台打印:// body
2、文本框手动获取焦点获取焦点,最常见的就是表单元素了,这里以文本框为例: <input type="text" id="name" /> 当把光标放到文本框内时,在控制台查看document.activeElement 对象。 document.activeElement: 
就是上面获取焦点的文本框。
3、通过focus获取焦点除了手动放到文本框内,让文本框获取焦点,也可以通过focus() 方法让文本框获取焦点。 <input type="text" id="name" /><script type="text/javascript"> // 文本框获取角度 document.querySelector("#name").focus(); console.log(document.activeElement); // 火狐浏览器控制台打印: // <input id="name" type="text"></script>
4、tab切换焦点网页中可以通过tab切换焦点,再来一个按钮试试: <input type="text" id="name" /><button>点我</button> 为了方便查看效果,设置一个定时器,5秒后打印document.activeElement: setTimeout(() => { console.log(document.activeElement); // 火狐浏览器控制台打印: // <button>}, 5000); 访问页面,通过tab切换到button按钮上,然后查看控制台输出: tab切换焦点: 
5、document.hasFocus()判断是否获取焦点同样的设置定时器查看: setTimeout(() => { console.log(document.hasFocus());}, 5000); - 访问页面时,如果切换到其他页面,5秒后回来查看就是
false 。表示用户并没有在操作页面。 - 如果停留在页面或者再页面操作,那么返回true,通过这个可以判断用户是否在操作页面。
到此这篇关于 JavaScript 中document.activeELement 焦点元素介绍的文章就介绍到这了,更多相关 JavaScript 中document.activeELement 焦点元素内容请搜索51zixue.net以前的文章或继续浏览下面的相关文章希望大家以后多多支持51zixue.net! 下载地址: Vue监听属性图文实例详解 JavaScript中MutationObServer监听DOM元素详情 |