news 2026/4/23 22:24:27

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/22 19:03:23

jQuery UI API 类别 - UI 核心(UI Core)

jQuery UI API 类别 - UI 核心(UI Core) UI Core(User Interface Core)是 jQuery UI 的基础核心类别,它提供了所有其他组件(Widgets、Interactions、Effects)所依赖的最底层功能。UI Core 本身…

作者头像 李华
网站建设 2026/4/23 10:45:11

【开题答辩全过程】以 基于Spark机器学习算法的体育新闻智能分类系统设计与实现为例,包含答辩的问题和答案

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

作者头像 李华
网站建设 2026/4/23 13:09:54

Dubbo 集群容错,你知道有几种方案?

文章目录Dubbo集群容错有几种方案?**第一部分:为什么我们需要集群容错?****第二部分:Dubbo 集群容错的几种方案****1. 负载均衡(Load Balancing)****Dubbo 的负载均衡策略有哪些?****如何配置负…

作者头像 李华
网站建设 2026/4/23 13:45:20

高效安全的私有文档问答系统:Langchain-Chatchat深度解析

高效安全的私有文档问答系统:Langchain-Chatchat深度解析 在企业知识管理日益复杂的今天,一个常见的痛点浮出水面:技术手册、合同模板、内部制度等关键文档散落在各个角落,员工查找信息耗时费力,而一旦依赖公有云AI服…

作者头像 李华
网站建设 2026/4/23 13:30:04

对话百胜软件数据产品专家文斌丨数据炼油厂与AI超级顾问:DATAMAX如何让零售数据“活”起来

百闻不如一践,【百胜智见】为您解码百胜零售数智实践~本期导读:在数据爆炸的时代,零售企业坐拥“数据金山”却常常陷入“数据贫困”的困境。如何将分散、沉睡的数据转化为驱动业务增长的“活水”?百胜软件DATAMAX数据中台给出了智…

作者头像 李华