news 2026/4/18 9:36:46

jQuery UI API 类别 - 选择器(Selectors)

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
jQuery UI API 类别 - 选择器(Selectors)

jQuery UI API 类别 - 选择器(Selectors)

Selectors是 jQuery UI API 中的一个独立类别,它扩展了 jQuery 的选择器功能,主要用于无障碍访问(Accessibility)场景,帮助开发者精确选中那些可以获得焦点或通过 Tab 键导航的元素。这些选择器属于 jQuery UI 的UI Core部分,内部实现考虑了跨浏览器兼容性和复杂规则(如 tabindex、disabled、visibility 等)。

官方文档地址:https://api.jqueryui.com/category/selectors/(适用于最新版本 1.14.1)

Selectors 类别包含的选择器

jQuery UI 提供了以下 4 个自定义选择器(以冒号:开头):

选择器描述关键规则与区别示例代码
:focusable选中所有可以获得焦点的元素(包括程序化焦点,如 tabindex=“-1”)。- 原生可焦点元素:input、select、textarea、button、object(未 disabled)。
- a/area:有 href 或 tabindex。
- 其他元素:有 tabindex(包括负值)。
- 元素必须可见。
$(":focusable").css("outline", "2px solid red");
:tabbable选中所有可以通过 Tab 键导航的元素(严格子集,不包括 tabindex=“-1”)。- 与 :focusable 类似,但 tabindex 必须 ≥0,且未 disabled。
- 注意:tabindex=“-1” 的元素是 :focusable 但不是 :tabbable。
$(":tabbable").addClass("tabbable-highlight");
:data(key)选中所有通过.data(key, value)存储了指定键数据的元素。- key:数据键名。
- 等价于有 jQuery data 的元素。
$(":data(myKey)").css("background", "yellow");
:data()(无参数)选中所有存储了任意 jQuery data 的元素。- 用于快速查找有 data 的元素。$(":data()").length; // 返回数量
为什么需要这些选择器?
  • 无障碍支持:标准 CSS 或 jQuery 选择器(如:focus)无法准确处理所有可焦点元素(尤其是 tabindex 和跨浏览器差异)。
  • 键盘导航:Dialog、Menu、Tabs 等小部件内部大量使用:tabbable来管理焦点陷阱(focus trapping)。
  • 数据管理:data()选择器方便操作 jQuery 存储的内部数据(如 Widget 实例)。
示例:高亮所有可 Tab 元素
$(function(){// 高亮所有可以通过 Tab 键访问的元素$(":tabbable").css({"outline":"2px dotted green","outline-offset":"2px"});// 高亮所有可焦点元素(包括 tabindex="-1")$(":focusable").css("box-shadow","0 0 5px blue");});
注意事项
  • 这些选择器依赖 jQuery UI的核心文件(jquery-ui.js),不引入 jQuery UI 时不可用。
  • 元素必须可见(display ≠ none,visibility ≠ hidden,且 opacity > 0)。
  • 项目已进入维护模式(最新 1.14.1),这些选择器稳定可靠,常用于键盘交互和 ARIA 无障碍开发。

如果您想了解某个选择器(如 :tabbable)的详细实现规则、完整代码示例,或在 Dialog 中的实际应用,请告诉我!

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/18 4:30:28

“零重写、少踩坑、快上线”——DBA小马哥亲历Oracle迁移到金仓迁移实战:一套兼容策略+三把自动化工具,让团队3天完成语法适配、2周交付生产库

大家好,我是DBA小马哥。今天要和大家分享的是一个非常实用的话题——如何从Oracle迁移到金仓数据库。作为一名资深数据库管理员,我经历过多次异构数据库的迁移项目,深知其中的技术挑战与实施难点。这次,我将结合一次真实的金融行业…

作者头像 李华
网站建设 2026/4/18 3:47:11

【开题答辩全过程】以 基于Java的电影推荐系统为例,包含答辩的问题和答案

个人简介一名14年经验的资深毕设内行人,语言擅长Java、php、微信小程序、Python、Golang、安卓Android等开发项目包括大数据、深度学习、网站、小程序、安卓、算法。平常会做一些项目定制化开发、代码讲解、答辩教学、文档编写、也懂一些降重方面的技巧。感谢大家的…

作者头像 李华
网站建设 2026/4/18 4:30:03

Python - 发送电子邮件

用Python发送电子邮件 你可以用 Python 发送邮件,使用多个库,但最常见的是 smtplib 和 email。 Python 中的“smtplib”模块定义了一个 SMTP 客户端会话对象,可用于向任何带有 SMTP 或 ESMTP 监听器守护进程的互联网机器发送邮件。电子邮件…

作者头像 李华
网站建设 2026/4/17 17:43:24

使用Langchain-Chatchat实现PDF、TXT、Word文档智能问答

使用Langchain-Chatchat实现PDF、TXT、Word文档智能问答 在企业知识管理日益复杂的今天,一个常见的痛点是:新员工入职后想了解“年假如何申请”,却要在十几个分散的PDF和Word文件中反复翻找;医生查阅最新诊疗指南时,面…

作者头像 李华
网站建设 2026/4/10 19:58:25

【AI时代下的Vibe coding实现细节】

AI时代下的Vibe coding实现细节 先分析梳理需求点,AI辅助编程的思路 一、前置条件检查URL格式验证确保以http://或https://开头HTTP方法验证只允许标准方法端点验证确保以斜杠开头URL格式验证 使用正则表达式严格校验URL格式,必须符合以下规则&#xff1…

作者头像 李华