非表单元素如何使用focus焦点事件

本文聚焦前端开发中的焦点事件。介绍了常用焦点事件focus和blur,指出默认表单元素可设置焦点事件,非表单元素外的元素不可设置。还说明了非表单元素添加tabindex属性就能使用焦点事件,且表单元素默认有tab导航效果,设置tabindex可优化用户体验。

在前端开发中,常用的焦点事件有focusblur

来看看在菜鸟教程(https://www.runoob.com/jsref/met-html-focus.html)中的介绍:

  • focus() 方法用于为元素设置焦点(如果可以设置)。
  • 提示:使用 blur()方法来移除元素焦点。

菜鸟教程里说“如果可以设置”,那么哪样的元素可以设置,哪样的元素又不可以设置呢?对于不可以设置焦点事件的元素,如何让它也能够使用焦点事件?One by one。

哪些元素可以设置focus/blur

默认表单元素可以设置焦点事件。那么表单元素都具体包含哪些呢?

继续去菜鸟教程(https://www.runoob.com/html/html-forms.html)里找答案:

  • 表单元素是允许用户在表单中输入内容,比如:文本域(textarea)、下拉列表、单选框(radio-buttons)、复选框(checkboxes)等等。

当然也少不了HTML5新增的表单元素,汇总如下图:

哪些元素不可以设置focus/blur

除上图所有表单元素之外。

非表单元素如何设置focus/blur

给非表单元素添加tabindex属性即可。

先看看W3school(http://www.w3school.com.cn/jquery/event_focus.asp)对focus事件的定义和用法:

  • 当元素获得焦点时,发生 focus 事件。
  • 当通过鼠标点击选中元素或通过 tab 键定位到元素时,该元素就会获得焦点。
  • focus() 方法触发 focus 事件,或规定当发生 focus 事件时运行的函数。

所以,要想让元素获得焦点, 可以鼠标点击,也可以使用tab键通过tabindex数值定位到。

再来看看W3school(http://www.w3school.com.cn/tags/att_standard_tabindex.asp)对此属性的介绍:

  • tabindex 属性规定元素的 tab 键控制次序(当 tab 键用于导航时)。

那么表单元素和tab键有什么关联?有时候我们浏览一个网页,特别是填写表单的页面,误触或按到tab键,发现焦点自动跑到表单元素,如下图:

当用户填写页面上那么多表单项时,不用我们手动点击鼠标一个个切换填写下一个表单项,而直接按下tab键以快速高效完成表单的填写。这就是(当 tab 键用于导航时)的意思。如此人性化的设计或网页规范标准大大节省了用户的时间,也给用户更佳的UI体验。 (ps:不仅表单元素,<a>元素也有tab导航的效果)

所以,可以理解为表单元素默认在创建后,默认会被赋予tabindex属性,按照文档顺序从上到下,值从1开始到最后。而非表单元素,若想使用焦点,也要拥有tabindex属性,为了不影响页面其他表单元素的tab导航切换操作顺序,一般给非表单元素设置属性:

tabindex=-1

以上。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

DayDayUp丶

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值