0

0

HTML焦点与键盘事件_html/css_WEB-ITnose

php中文网

php中文网

发布时间:2016-06-24 11:45:57

|

1510人浏览过

|

来源于php中文网

原创

所谓焦点就是用户当前正在操作的对象,可以是某个元素,也可能是某个浏览器中的tab或window。比如用鼠标点击输入框,那么输入框就会成为焦点。使用键盘上的tab键,又可以把焦点转移到另外一个元素或浏览器的其他区域。通过鼠标和键盘都可以转移焦点,甚至编辑焦点元素。

焦点元素

同一时间一个document只能有一个元素成为焦点,这个焦点元素可以使用JavaScript访问:

立即学习前端免费学习笔记(深入)”;

document.activeElement;

立即学习前端免费学习笔记(深入)”;

如果没有元素成为焦点,默认是body元素作为activeElement。成为焦点的元素对应CSS的:focus伪类。

但不是所有元素都可以成为焦点,只有拥有可获焦区域的DOM锚才可以称为焦点:

可获焦区域

可获焦区域可能是元素,元素的部分或用户代理管理的其他部分,每一个可获焦区域有一个DOM锚,这个锚是一个Node对象,Node对象的位置就是可获焦区域在DOM中的位置。可获焦区域的API目前就通过这个锚来操作可获焦区域。

不是所有Node都能表示焦点区域,Node要变成焦点区域需要满足一些条件。下表只是列出了一些常见的可获焦区域和它的DOM锚:

可获焦区域

DOM锚

有tabindex焦点标志,并且没有disabled属性的元素

元素本身

Image map中area的图形区域

img元素

用户代理提供的可获焦子控件,比如input[type=number]生成的上下两个按钮

生成子控件的元素

元素的滚动区域

产生滚动区域的元素

浏览上下文内document的viewport,比如iframe产生的视窗。

为之产生viewport的document

WordToCard
WordToCard

文章转知识卡片,让知识表达更优雅。

下载

tabindex焦点标记

使用键盘上的tab键,可以按顺序切换当前焦点元素,而影响这个切换顺序的属性就是元素的tabindex属性。这个属性的取值范围是0到32767,如果赋值为负数则表示没有焦点标记,不对它进行切换。

但并不是所有元素设置了tabindex就一定可以使用tab键切换成为焦点,首先tabindex的值不能为负数,而且不能有disabled属性。另外,这个元素必须有对应的可获焦区域,而且支持tabindex属性。HTML4规定FORM表单中只有以下元素支持tabindex属性:a、area、button、input、object、select、textarea。

没有显式设置tabindex属性的元素就不能通过Tab键切换成为焦点?也不是,只要元素拥有tabindex焦点标记就可以。W3C推荐用户代理自动为以下元素设置tabindex焦点标记:

  • 有href属性的a元素;
  • 有href属性的link元素;
  • button元素;
  • type不是hidden的input元素;
  • select元素;
  • textarea元素;
  • iframe、frame元素;
  • menuitem元素;
  • 设置了draggable属性的元素;
  • 设置了contenteditable属性的元素;
  • 默认这些元素的tabindex为0。以上只是W3C推荐的元素,不同的浏览器实现可能不一样。比如在Chrome41中,如果不是上述元素,即使设置了合法的tabindex也不会被tab键切换到,而在IE和Firefox中,只要设置了合法的tabindex就可以被tab切换到。

    切换顺序规则

    由先到后的顺序是:

    1.        元素的tabindex大于0的元素,按tabindex从小到大顺序切换;

    2.        元素的tabindex相同的,按元素在document中的出现顺序切换;

    3.        元素的tabindex为0,或没有设置tabindex,或tabindex不是有效整数(后两种等同于tabindex=0),按元素在document中的出现顺序切换;

    focus & focusin, blur & focusout

    一个元素成为active元素就等于获得了焦点,会触发这个元素的focus事件。有元素获得焦点,一般就有元素会失去焦点,失去焦点的元素触发blur事件。这两个事件几乎是同时发生的,但他们的执行顺序有区别,blur事件的监听方法先执行,然后才是focus事件的监听方法。

    元素在document没有加载完之前是不能获得焦点的,获得焦点的元素通过documnt.activeElement可以访问。

    Focusin也是元素在即将获取焦点的时候触发的事件,它和focus的主要区别是focus事件没有冒泡阶段。因为focusin事件有冒泡阶段,因此可以用来监听本元素及其子元素获取焦点的情况。同理,blur事件也没有冒泡阶段,而focusout有。

    兼容性:

  • Firefox不支持focusin和focusout事件;
  • Chrome,获取焦点执行顺序:onfocus,onfocusin;失去焦点执行顺序:onblur, onfocusout。
  • IE6,IE7,IE8,IE9,IE10,获取焦点执行顺序:onfocusin ,onfocus;失去焦点执行顺序:onfocusout ,onblur。
  • 键盘事件

    在DOM中,有几个键盘事件总是以获得焦点的元素作为目标的。

    Keypress, keydown, keyup的区别

    KeyPress主要用来接收字母、数字等ANSI字符,而 KeyDown 和 KeyUP 事件过程可以处理任何不被KeyPress 识别的击键,诸如:功能键(F1-F12)、编辑键、定位键以及任何这些键和键盘换档键的组合等。

    三个事件的触发顺序按从早到晚:keydown、keypress、keyup。Keydown和keypress事件监听方法执行的时候,刚才敲入的字符还没有显示在输入框中,要等这些事件监听方法执行完后才插入。Keyup事件监听方法执行的时候,字符已经显示在输入框中。

    立即学习前端免费学习笔记(深入)”;

    如果摁住某个键不放,会间隔触发keypress和keydown事件,但只要你不放开,就不会触发keyup,keyup只有当你放开这个键才会触发。


    相关文章

    HTML速学教程(入门课程)
    HTML速学教程(入门课程)

    HTML怎么学习?HTML怎么入门?HTML在哪学?HTML怎么学才快?不用担心,这里为大家提供了HTML速学教程(入门课程),有需要的小伙伴保存下载就能学习啦!

    下载

    本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

    热门AI工具

    更多
    DeepSeek
    DeepSeek

    幻方量化公司旗下的开源大模型平台

    豆包大模型
    豆包大模型

    字节跳动自主研发的一系列大型语言模型

    通义千问
    通义千问

    阿里巴巴推出的全能AI助手

    腾讯元宝
    腾讯元宝

    腾讯混元平台推出的AI助手

    文心一言
    文心一言

    文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

    讯飞写作
    讯飞写作

    基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

    即梦AI
    即梦AI

    一站式AI创作平台,免费AI图片和视频生成。

    ChatGPT
    ChatGPT

    最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

    相关专题

    更多
    pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法
    pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法

    本专题系统整理pixiv网页版官网入口及登录访问方式,涵盖官网登录页面直达路径、在线阅读入口及快速进入方法说明,帮助用户高效找到pixiv官方网站,实现便捷、安全的网页端浏览与账号登录体验。

    616

    2026.02.13

    微博网页版主页入口与登录指南_官方网页端快速访问方法
    微博网页版主页入口与登录指南_官方网页端快速访问方法

    本专题系统整理微博网页版官方入口及网页端登录方式,涵盖首页直达地址、账号登录流程与常见访问问题说明,帮助用户快速找到微博官网主页,实现便捷、安全的网页端登录与内容浏览体验。

    194

    2026.02.13

    Flutter跨平台开发与状态管理实战
    Flutter跨平台开发与状态管理实战

    本专题围绕Flutter框架展开,系统讲解跨平台UI构建原理与状态管理方案。内容涵盖Widget生命周期、路由管理、Provider与Bloc状态管理模式、网络请求封装及性能优化技巧。通过实战项目演示,帮助开发者构建流畅、可维护的跨平台移动应用。

    91

    2026.02.13

    TypeScript工程化开发与Vite构建优化实践
    TypeScript工程化开发与Vite构建优化实践

    本专题面向前端开发者,深入讲解 TypeScript 类型系统与大型项目结构设计方法,并结合 Vite 构建工具优化前端工程化流程。内容包括模块化设计、类型声明管理、代码分割、热更新原理以及构建性能调优。通过完整项目示例,帮助开发者提升代码可维护性与开发效率。

    20

    2026.02.13

    Redis高可用架构与分布式缓存实战
    Redis高可用架构与分布式缓存实战

    本专题围绕 Redis 在高并发系统中的应用展开,系统讲解主从复制、哨兵机制、Cluster 集群模式及数据分片原理。内容涵盖缓存穿透与雪崩解决方案、分布式锁实现、热点数据优化及持久化策略。通过真实业务场景演示,帮助开发者构建高可用、可扩展的分布式缓存系统。

    54

    2026.02.13

    c语言 数据类型
    c语言 数据类型

    本专题整合了c语言数据类型相关内容,阅读专题下面的文章了解更多详细内容。

    29

    2026.02.12

    雨课堂网页版登录入口与使用指南_官方在线教学平台访问方法
    雨课堂网页版登录入口与使用指南_官方在线教学平台访问方法

    本专题系统整理雨课堂网页版官方入口及在线登录方式,涵盖账号登录流程、官方直连入口及平台访问方法说明,帮助师生用户快速进入雨课堂在线教学平台,实现便捷、高效的课程学习与教学管理体验。

    15

    2026.02.12

    豆包AI网页版入口与智能创作指南_官方在线写作与图片生成使用方法
    豆包AI网页版入口与智能创作指南_官方在线写作与图片生成使用方法

    本专题汇总豆包AI官方网页版入口及在线使用方式,涵盖智能写作工具、图片生成体验入口和官网登录方法,帮助用户快速直达豆包AI平台,高效完成文本创作与AI生图任务,实现便捷智能创作体验。

    598

    2026.02.12

    PostgreSQL性能优化与索引调优实战
    PostgreSQL性能优化与索引调优实战

    本专题面向后端开发与数据库工程师,深入讲解 PostgreSQL 查询优化原理与索引机制。内容包括执行计划分析、常见索引类型对比、慢查询优化策略、事务隔离级别以及高并发场景下的性能调优技巧。通过实战案例解析,帮助开发者提升数据库响应速度与系统稳定性。

    56

    2026.02.12

    热门下载

    更多
    网站特效
    /
    网站源码
    /
    网站素材
    /
    前端模板

    精品课程

    更多
    相关推荐
    /
    热门推荐
    /
    最新课程
    关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
    php中文网:公益在线php培训,帮助PHP学习者快速成长!
    关注服务号 技术交流群
    PHP中文网订阅号
    每天精选资源文章推送

    Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号