0

0

使用 tabindex 配合 focus-within 巧妙实现父选择器

絕刀狂花

絕刀狂花

发布时间:2025-09-25 08:38:01

|

760人浏览过

|

来源于php中文网

原创

本文将介绍一个不常用的技巧,通过 tabindex:focus-within 的巧妙组合,实现类似父选择器的功能。

在 CSS 中是否存在父选择器?这是个经典的问题。目前为止,CSS 并没有被广泛实现的父选择器,这与浏览器的渲染机制有关。

如果你对 CSS 中是否存在父选择器有疑问,可以参考 知乎上的讨论 -- CSS 中能否选择父元素?

当然,这并不意味着 CSS 完全无法通过子元素控制父元素。利用 :focus-within 伪类,我们可以达到类似的效果。

:focus-within 伪类简介:focus-within 是一个伪类,表示一个元素获得焦点,或其后代元素获得焦点。重点是它或其后代获得焦点。

如果你对 :focus-within 不太了解,可以先阅读这篇文章:《神奇的选择器 :focus-within》

通过这个伪类,我们可以实现类似这样的功能:当子元素获得焦点(focus事件)时,触发该伪类,从而实现一个狭义的父选择器,类似于:

使用 tabindex 配合 focus-within 巧妙实现父选择器CodePen -- CSS focus-within INPUT

:focus-within 伪类实现父选择的局限性利用 :focus-within 实现父类选择器的最大问题是,元素必须有 focus 事件,才能触发它或其父元素的 :focus-within

因此,我之前认为 :focus-within 只能与 等元素一起使用。

这大大限制了它的使用场景。基于此,我们引入本文的另一个主角 -- tabindex

使用 tabindex 使元素获得 focus 事件tabindex 是 HTML 标签的一个属性,表示元素是否可以聚焦,以及它在键盘导航中的顺序(通常使用Tab键)。

也就是说,一个普通的

标签是没有 focus 事件的,但如果我们给它加上 tabindex 属性,它就会像 框一样获得 focus 事件,再结合 :focus-within,可以大大扩展其应用场景。

看看伪代码:

结合 :focus-within,当点击子元素时,就可以改变父元素的样式。

并且,我们可以在任何元素上使用 tabindex,不再受限于 等元素才有 focus 事件。

.g-father:focus-within {
    background: #fc0;
}

使用 tabindex 配合 focus-within 巧妙实现父选择器CodePen -- tabindex 配合 focus-within 实现div的父选择器

Kite
Kite

代码检测和自动完成工具

下载

一个小细节,button 的 focus 事件在 Safari 和 Firefox 上的冒泡问题由于 元素(或任意元素 + tabindex) 结合 :focus-within 的方案依赖于 focus 事件的冒泡。

对于 元素,有两个特殊问题:

  • 在 MacOS 的 Safari 和 Firefox 中,点击 元素,不会触发 focus 事件,也没有 focus 事件冒泡
  • 在 Windows 的 Safari 和 Firefox 中,点击 元素,会触发 focus 事件,但在被目标元素捕捉到之后,不会继续向上冒泡。

我们来验证一下,使用类似这样的结构:



在 Chrome 下的表现:

使用 tabindex 配合 focus-within 巧妙实现父选择器在 Windows 的 Safari 和 Firefox 下的表现:

使用 tabindex 配合 focus-within 巧妙实现父选择器在 MacOS 的 Safari 和 Firefox 下的表现:

使用 tabindex 配合 focus-within 巧妙实现父选择器在 Chrome 上表现正常,而在 Windows 的 Safari 和 Firefox 上,会触发 focus 事件,但不会触发父元素的 :focus-within 事件,即 focus 事件在被目标元素捕捉到之后,不会继续向上冒泡。而在 Mac 上,则连 focus 都不会触发。

使用时务必注意这一点。

CodePen -- button 的 focus 事件冒泡性验证(Chorme / Safari / Firefox)

使用 tabindex 配合 focus-within 巧妙实现父选择器最后当然,本文介绍的技巧,只能算是一个非常简陋,特定条件(点击目标元素改变父元素样式)下的父选择器,真正意义上的父选择器仍需等待未来规范的实现。

好了,本文到此结束,希望对你有帮助 :)

更多精彩 CSS 技术文章汇总在我的 Github -- iCSS ,持续更新,欢迎点个 star 订阅收藏。

如果还有什么疑问或者建议,可以多多交流,原创文章,文笔有限,才疏学浅,文中若有不正之处,万望告知。

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

通义千问
通义千问

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

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
chrome什么意思
chrome什么意思

chrome是浏览器的意思,由Google开发的网络浏览器,它在2008年首次发布,并迅速成为全球最受欢迎的浏览器之一。本专题为大家提供chrome相关的文章、下载、课程内容,供大家免费下载体验。

826

2023.08.11

chrome无法加载插件怎么办
chrome无法加载插件怎么办

chrome无法加载插件可以通过检查插件是否已正确安装、禁用和启用插件、清除插件缓存、更新浏览器和插件、检查网络连接和尝试在隐身模式下加载插件方法解决。更多关于chrome相关问题,详情请看本专题下面的文章。php中文网欢迎大家前来学习。

742

2023.11.06

点击input框没有光标怎么办
点击input框没有光标怎么办

点击input框没有光标的解决办法:1、确认输入框焦点;2、清除浏览器缓存;3、更新浏览器;4、使用JavaScript;5、检查硬件设备;6、检查输入框属性;7、调试JavaScript代码;8、检查页面其他元素;9、考虑浏览器兼容性。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

185

2023.11.24

github中文官网入口 github中文版官网网页进入
github中文官网入口 github中文版官网网页进入

github中文官网入口https://docs.github.com/zh/get-started,GitHub 是一种基于云的平台,可在其中存储、共享并与他人一起编写代码。 通过将代码存储在GitHub 上的“存储库”中,你可以: “展示或共享”你的工作。 持续“跟踪和管理”对代码的更改。

704

2026.01.21

windows查看端口占用情况
windows查看端口占用情况

Windows端口可以认为是计算机与外界通讯交流的出入口。逻辑意义上的端口一般是指TCP/IP协议中的端口,端口号的范围从0到65535,比如用于浏览网页服务的80端口,用于FTP服务的21端口等等。怎么查看windows端口占用情况呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

734

2023.07.26

查看端口占用情况windows
查看端口占用情况windows

端口占用是指与端口关联的软件占用端口而使得其他应用程序无法使用这些端口,端口占用问题是计算机系统编程领域的一个常见问题,端口占用的根本原因可能是操作系统的一些错误,服务器也可能会出现端口占用问题。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

1128

2023.07.27

windows照片无法显示
windows照片无法显示

当我们尝试打开一张图片时,可能会出现一个错误提示,提示说"Windows照片查看器无法显示此图片,因为计算机上的可用内存不足",本专题为大家提供windows照片无法显示相关的文章,帮助大家解决该问题。

799

2023.08.01

windows查看端口被占用的情况
windows查看端口被占用的情况

windows查看端口被占用的情况的方法:1、使用Windows自带的资源监视器;2、使用命令提示符查看端口信息;3、使用任务管理器查看占用端口的进程。本专题为大家提供windows查看端口被占用的情况的相关的文章、下载、课程内容,供大家免费下载体验。

454

2023.08.02

Python 自然语言处理(NLP)基础与实战
Python 自然语言处理(NLP)基础与实战

本专题系统讲解 Python 在自然语言处理(NLP)领域的基础方法与实战应用,涵盖文本预处理(分词、去停用词)、词性标注、命名实体识别、关键词提取、情感分析,以及常用 NLP 库(NLTK、spaCy)的核心用法。通过真实文本案例,帮助学习者掌握 使用 Python 进行文本分析与语言数据处理的完整流程,适用于内容分析、舆情监测与智能文本应用场景。

10

2026.01.27

热门下载

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

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Sass 教程
Sass 教程

共14课时 | 0.8万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 3万人学习

CSS教程
CSS教程

共754课时 | 24.3万人学习

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

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