盘点JavaScript focus/blur(聚焦)实际应用

Karen110
• 阅读 1488

大家好,我进阶学习者。

一、前言

当用户点击某个元素或使用键盘上的 Tab 键选中时,该元素将会获得聚焦(focus)。当网页加载时,HTML-特性(attribute)。

autofocus也可以让一个焦点落在元素上,不仅如此,还有其它途径可以获得焦点。

二、focus/blur 事件

当元素聚焦时,会触发 focus事件,当元素失去焦点时,会触发 blur事件。让使用它们来校验一个 input字段。

1. 案例分析

blur事件处理程序检查这个字段是否输入了电子邮箱,如果没有输入,则显示一个 error。

focus事件处理程序隐藏 error 信息(在blur事件处理程序上会被再检查一遍)。

2. 代码


<style>
  .invalid { border-color: red; }
  #error { color: red }
</style>
Your email please: 
<input type="email" id="input">
<div id="error">
</div>
<script>
input.onblur = function() {
  if (!input.value.includes('@')) { // not email
    input.classList.add('invalid');
    error.innerHTML = 'Please enter a correct email.'
  }
};
input.onfocus = function() {
  if (this.classList.contains('invalid')) {
    // 移除 "error" 指示,因为用户想要重新输入一些内容
    this.classList.remove('invalid');
    error.innerHTML = "";
  }
};
</script>

盘点JavaScript focus/blur(聚焦)实际应用

注:

现代 HTML 允许使用 input特性(attribute),进行许多验证:required,pattern等。

有时它们正是所需要的。当需要更大的灵活性时,可以使用 JavaScript。如果数据是正确的,可以把它自动发送到服务器。

三、focus/blur 方法

elem.focus()和 elem.blur()方法可以设置和移除元素上的焦点。

例:

如果输入值无效,可以让焦点无法离开这个 input字段:

<body style="background-color: aqua;">
Your email please: 
  <input type="email" id="input">
    <input type="text" style="width:220px" placeholder="make email invalid and try to focus here">
    <script>
        input.onblur = function() {
            if (!this.value.includes('@')) { // not email
                // 显示 error
                this.classList.add("error");
                // ...将焦点放回来
                input.focus();
            } else {
                this.classList.remove("error");
            }
        };
</script>
</body>

盘点JavaScript focus/blur(聚焦)实际应用

注:

如果在 input中输入一些内容,然后尝试使用 Tab 键或点击远离 的位置,那么 onblur事件处理程序会把焦点重新设置到这个 input字段上。

四、focus/blur 委托

focus和blur事件不会向上冒泡。

例如,不能把 onfocus放在

上来对其进行高亮,像这样:


<!-- on focusing in the form -- add the class -->
<form onfocus="this.className='focused'">
  <input type="text" name="name" value="Name">
  <input type="text" name="surname" value="Surname">
</form>
<style> 
  .focused { 

    outline: 1px solid red; 
  } 
</style>

当用户聚焦于 时,focus事件只会在该 上触发。它不会向上冒泡。所以 form.onfocus永远不会触发。

form.onfocus永远不会触发,(两个解决方案)。

1. 方案一

有一个遗留下来的有趣的特性(feature):focus/blur不会向上冒泡,但会在捕获阶段向下传播。


<form id="form">
  <input type="text" name="name" value="Name">
  <input type="text" name="surname" value="Surname">
</form>
<style> 
  .focused {
    outline: 1px solid red; 
  } 
</style>
<script>
  // 将处理程序置于捕获阶段(最后一个参数为 true)
  form.addEventListener("focus", () => form.classList.add('focused'), true);
  form.addEventListener("blur", () => form.classList.remove('focused'), true);
</script>

2. 方案二

可以使用 focusin和 focusout事件 —— 与 focus/blur事件完全一样,只是它们会冒泡。

注意:必须使用 elem.addEventListener来分配它们,而不是 on

所以,这是另一个可行的变体:


<form id="form">
  <input type="text" name="name" value="Name">
  <input type="text" name="surname" value="Surname">
</form>
<style> 
  .focused { 
    outline: 1px solid red; 
  } 
</style>
<script>
  form.addEventListener("focusin", () => form.classList.add('focused'));
  form.addEventListener("focusout", () => form.classList.remove('focused'));
</script>

一样的结果:

盘点JavaScript focus/blur(聚焦)实际应用

五、总结


本文基于JavaScript基础,介绍了focus/blur(聚焦)实际应用。通过事件以及对方法的讲解。在元素获得/失去焦点时会触发 focus和 blur事件,通过 document.activeElement来获取当前所聚焦的元素。focus/blur 委托时遇到的问题,提供了两个有效的解决方案。

欢迎大家积极尝试,有时候看到别人实现起来很简单,但是到自己动手实现的时候,总会有各种各样的问题,切勿眼高手低,勤动手,才可以理解的更加深刻。

通过代码的演示,运行效果图的展示,能够让读者更直观的理解,更好的学习。

代码很简单,希望能够帮助你更好的学习。

**-----**------**-----**---**** End **-----**--------**-----**-****

往期精彩文章推荐:

盘点JavaScript focus/blur(聚焦)实际应用

欢迎各位大佬点击链接加入群聊【helloworld开发者社区】:https://jq.qq.com/?_wv=1027&k=mBlk6nzX进群交流IT技术热点。

点赞
收藏
评论区
推荐文章
blmius blmius
3年前
MySQL:[Err] 1292 - Incorrect datetime value: ‘0000-00-00 00:00:00‘ for column ‘CREATE_TIME‘ at row 1
文章目录问题用navicat导入数据时,报错:原因这是因为当前的MySQL不支持datetime为0的情况。解决修改sql\mode:sql\mode:SQLMode定义了MySQL应支持的SQL语法、数据校验等,这样可以更容易地在不同的环境中使用MySQL。全局s
Karen110 Karen110
3年前
一篇文章带你了解JavaScript日期
日期对象允许您使用日期(年、月、日、小时、分钟、秒和毫秒)。一、JavaScript的日期格式一个JavaScript日期可以写为一个字符串:ThuFeb02201909:59:51GMT0800(中国标准时间)或者是一个数字:1486000791164写数字的日期,指定的毫秒数自1970年1月1日00:00:00到现在。1\.显示日期使用
皕杰报表之UUID
​在我们用皕杰报表工具设计填报报表时,如何在新增行里自动增加id呢?能新增整数排序id吗?目前可以在新增行里自动增加id,但只能用uuid函数增加UUID编码,不能新增整数排序id。uuid函数说明:获取一个UUID,可以在填报表中用来创建数据ID语法:uuid()或uuid(sep)参数说明:sep布尔值,生成的uuid中是否包含分隔符'',缺省为
待兔 待兔
4个月前
手写Java HashMap源码
HashMap的使用教程HashMap的使用教程HashMap的使用教程HashMap的使用教程HashMap的使用教程22
Stella981 Stella981
3年前
Android So动态加载 优雅实现与原理分析
背景:漫品Android客户端集成适配转换功能(基于目标识别(So库35M)和人脸识别库(5M)),导致apk体积50M左右,为优化客户端体验,决定实现So文件动态加载.!(https://oscimg.oschina.net/oscnet/00d1ff90e4b34869664fef59e3ec3fdd20b.png)点击上方“蓝字”关注我
Stella981 Stella981
3年前
Python之time模块的时间戳、时间字符串格式化与转换
Python处理时间和时间戳的内置模块就有time,和datetime两个,本文先说time模块。关于时间戳的几个概念时间戳,根据1970年1月1日00:00:00开始按秒计算的偏移量。时间元组(struct_time),包含9个元素。 time.struct_time(tm_y
Stella981 Stella981
3年前
JavaScript事件
事件通常与函数配合使用,这样就可以通过发生的事件来驱动函数执行。FF:Firefox,N:Netscape,IE:InternetExplorer属性当以下情况发生时,出现此事件     FF  N   IEonabort图像加载被中断134onblur元素失去焦点1
Wesley13 Wesley13
3年前
(绝对有用)iOS获取UUID,并使用keychain存储
UDID被弃用,使用UUID来作为设备的唯一标识。获取到UUID后,如果用NSUserDefaults存储,当程序被卸载后重装时,再获得的UUID和之前就不同了。使用keychain存储可以保证程序卸载重装时,UUID不变。但当刷机或者升级系统后,UUID还是会改变的。但这仍是目前为止最佳的解决办法了,如果有更好的解决办法,欢迎留言。(我整理的解决办法的参
Stella981 Stella981
3年前
Noark入门之异步事件
引入异步事件主要是为了各模块的解耦,每当完成一个动作时,向系统发布一个事件,由关心的模块自己监听处理,可选择同步处理,异步处理,延迟处理。何时发布事件,当其他模块关心此动作时<br比如获得道具时,任务系统模块要判定完成进度,BI模块需要上报等等都可以监听此事件,已达模块解耦0x00事件源一个实现xyz.noark.core.event
Stella981 Stella981
3年前
JavaScript 基础(四)
HTMLDOMEvent(事件)HTML4.0的新特性之一是有能力使HTML事件触发浏览器中的动作(action),比如当用户点击某个HTML元素时启动一段JavaScript。下面是一个属性列表,这些属性可插入HTML标签来定义事件动作。onclick//当用户点