HTML5实战与剖析之焦点管理(activeElement和hasFocus)

原文地址

  现在的网站越来越注重残障人士了,很多网站都开始有专为视力不好的人们制作一些便捷通道,方便他们进行浏览网页。下面就为大家介绍一下有关焦点管理和盲人网站方面的事儿,希望能对大家有所帮助。

  21世纪的网站,越来越注重残障人士了,其他伤残类型还好说一些,要是视力方面不太好的人们去浏览网站,基本上是不知道怎么浏览。视力不好的人们去浏览基本上是靠获取焦点来浏览网站的,主要是靠获取焦点以后读取内容来浏览网站的。所以焦点管理在为视力不好的人们制作网站的时候是尤为重要的。

  正因为考虑到视力不好的人们是客观存在的,所以HTML5添加了辅助管理DOM焦点的功能。


  1、document.activeElement属性


  Document.activeelement属性始终会引用DOM中当前获得了焦点的元素。元素获得焦点的方式有用户输入(通常是按Tab键)、在代码中调用focus()方法和页面加载。先来看个小例子。


  HTML代码



 
 
  1. <body id="body">
  2. <input id="btn" type="button" value="梦龙小站" />
  3. </body>

  JavaScript代码



 
 
  1. window.onload = function(){
  2. var btn = document.getElementById( "btn");
  3. //页面加载获取焦点
  4. alert( document.activeElement.id) // body
  5. //调用focus()方法获取焦点
  6. btn.focus();
  7. alert( document.activeElement.id) // btn
  8. };

  默认情况下,文档刚刚加载完成的时候,document.activeelement中保存的是document.body元素的引用。文档加载期间,document.activeelement的值为null。通过document.activeelement可以判断文档是否加载完成。


  2、document.hasFocus()方法


  HTML5除了新添加了document.activeelement属性,还添加了document.hasfocus()方法。这个方法用于确定文档是否获得了焦点。先来看个小例子。


  HTML代码



 
 
  1. <body id="body">
  2. <input id="btn" type="button" value="梦龙小站" />
  3. </body>

  JavaScript代码



 
 
  1. window.onload = function(){
  2. var btn = document.getElementById( "btn");
  3. alert( document.hasFocus()) //true
  4. };

  有了hasFocus()方法,我们就可以检测文档是否获得了焦点,可以知道用户是不是在与页面交互。

  查询文档获知哪个元素获得了焦点,以及确定文档是否获得了焦点,这两个功能最重要的用途是提供Web应用的无障碍性。无障碍Web应用的一个主要标志就是恰当的焦点管理,而确切知道哪个元素获得了焦点是一个极大的进步,至少我们不用像过去一样靠猜测了。先来看个小例子。


  hasFocus()应用小例子


  HTML代码



 
 
  1. <div id="meng">鼠标放上来 </div>
  2. <div id="long" style="display:none;">获取焦点了 </div>

  JavaScript代码



 
 
  1. window.onload = function(){
  2. var oMeng = document.getElementById( "meng");
  3. var oLong = document.getElementById( "long");
  4. oMeng.onmouseover = getFocus;
  5. oMeng.onmouseout = loseFocus;
  6. function getFocus(){
  7. if ( document.hasFocus())
  8. {
  9. oLong.style.display = "block";
  10. }
  11. }
  12. function loseFocus(){
  13. oLong.style.display = "none";
  14. }
  15. };

  上面这个例子充分运用了hasFocus()方法来判断是否获得了焦点。从而也让我们感觉了一下hasFocus()方法的魅力,以及焦点管理的用处。能够实现这hasFocus()方法和activeElement属性的浏览器有:FireFox 3+、Safari 4+、Chrome、Opera 8+ 和IE 4+。




  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值