javascript中的焦点管理

焦点作为javascript中的一个重要功能,基本上和页面交互都离不开焦点。但却少有人对焦点管理系统地做总结归纳。本文就javascript中的焦点管理作详细介绍

焦点元素

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

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

blur

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

focus

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

focusin

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

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>

时间: 2024-10-08 03:27:57

javascript中的焦点管理的相关文章

理解javascript中的焦点管理

焦点作为javascript中的一个重要功能,基本上和页面交互都离不开焦点.但却少有人对焦点管理系统地做总结归纳.本文就javascript中的焦点管理作详细介绍 焦点元素 到底哪些元素可以获得焦点呢?默认情况下,只有表单元素可以获得焦点.因为只有表单元素可以交互 <input type="text" value="223"> 让非表单元素获得焦点也是有办法的,先将tabIndex属性设置为-1,再调用focus()方法 <div id="

深入理解javascript中的焦点管理

× 目录 [1]焦点元素 [2]获得焦点 [3]失去焦点[4]焦点事件 前面的话 焦点作为javascript中的一个重要功能,基本上和页面交互都离不开焦点.但却少有人对焦点管理系统地做总结归纳.本文就javascript中的焦点管理作详细介绍 焦点元素 到底哪些元素可以获得焦点呢?默认情况下,只有表单元素可以获得焦点.因为只有表单元素可以交互 <input type="text" value="223"> 让非表单元素获得焦点也是有办法的,先将tabI

JavaScript中的Event事件对象详解

JavaScript事件[event] 在JavaScript中对于事件来讲,首先,我们需要了解这样几个概念:事件:事件处理程序:事件类型:事件流:事件冒泡:事件捕获:事件对象:浏览器内核:事件绑定:事件方面的性能优化(事件委托.移除事件处理程序):常见的浏览器兼容问题等. 什么是事件event: JavaScript事件是:浏览器.文档(document)窗口中的发生的特定的交互瞬间:而JavaScript和HTML之间的交互行为就是通过事件来触发的. 事件处理程序: 事件处理程序:我们用户在

了解javascript中的事件(二)

零.寒暄 这篇博客本该出现在两个月以前,但是种种原因,搁浅了.两个月的时间,改变了许多人也改变了许多事,回头看看自己两个月前写的代码,居然有很多可笑之处,这也算是一种成长吧.实习的几个月里,全身心的投入工作,效率奇高,同时,离开学校的这段日子让我充分感受了这个社会的残酷.好酒需陈酿,来的早不如来的巧,今天跟大家分享下javascript中事件的下半部分. 如需查看本文的上一篇,请猛击了解javascript中的事件(一),注:后文如无特殊说明,提到的参考之前的博客,也是指这篇文章. 本文主要谈一

转---深入浅出妙用 Javascript 中 apply、call、bind

作者:伯乐在线专栏作者 - chokcoco 如有好文章投稿,请点击 → 这里了解详情 如需转载,发送「转载」二字查看说明 这篇文章实在是很难下笔,因为网上相关文章不胜枚举. 巧合的是前些天看到阮老师的一篇文章的一句话: "对我来说,博客首先是一种知识管理工具,其次才是传播工具.我的技术文章,主要用来整理我还不懂的知识.我只写那些我还没有完全掌握的东西,那些我精通的东西,往往没有动力写.炫耀从来不是我的动机,好奇才是." 对于这句话,不能赞同更多,也让我下决心好好写这篇,网上文章虽多,

JavaScript 中的内存泄漏

JavaScript 是一种垃圾收集式语言,这就是说,内存是根据对象的创建分配给该对象的,并会在没有对该对象的引用时由浏览器收回.JavaScript 的垃圾收集机制本身并没有问题,但浏览器在为 DOM 对象分配和恢复内存的方式上却有些出入. Internet Explorer 和 Mozilla Firefox 均使用引用计数来为 DOM 对象处理内存.在引用计数系统,每个所引用的对象都会保留一个计数,以获悉有多少对象正在引用它.如果计数为零,该对象就会被销毁,其占用的内存也会返回 给堆.虽然

javascript中常用的事件绑定方法

我们要想让 JavaScript 对用户的操作作出响应,首先要对 DOM 元素绑定事件处理函数.所谓事件处理函数,就是处理用户操作的函数,不同的操作对应不同的名称. 在JavaScript中,有三种常用的绑定事件的方法: 在DOM元素中直接绑定: 在JavaScript代码中绑定: 绑定事件监听函数. 一. 在DOM元素中直接绑定 这里的DOM元素,可以理解为HTML标签.JavaScript支持在标签中直接绑定事件,语法为:    onXXX="JavaScript Code" 其中

Javascript 中的函数式编程

本文和大家分享的主要是javascript中函数式编程相关内容,一起来看看吧,希望对大家学习javascript有所帮助. 函数式编程(functional programming)或称函数程序设计,又称泛函编程,是一种编程范型,比起命令式编程,函数式编程更加强调程序执行的结果而非执行的过程,倡导利用若干简单的执行单元让计算结果不断渐进,逐层推导复杂的运算,而不是设计一个复杂的执行过程. 函数式编程,近年来一直被炒得火热,国内外的开发者好像都在议论和提倡这种编程范式.在众多的函数式语言中,Jav

理解JavaScript中的事件处理 阻止冒泡event.stopPropagation();

原文地址:http://www.cnblogs.com/binyong/articles/1750263.html 这篇文章对于了解Javascript的事件处理机制非常好,将它全文转载于此,以备不时之需. 什么是事件? 事件(Event)是JavaScript应用跳动的心脏 ,也是把所有东西粘在一起的胶水.当我们与浏览器中 Web 页面进行某些类型的交互时,事件就发生了.事件可能是用户在某些内容上的点击.鼠标经过某个特定元素或按下键盘上的某些按键.事件还可能是 Web 浏览器中发生的事情,比如