使用css `focus-visible` 改善用户体验

focus-visible 是一个非常有用的 CSS 伪类,它解决了 Web 可访问性中的一个重要问题
:focus-visible 用于在特定情况下为元素添加焦点样式,而不是像 :focus 那样总是显示焦点环。

css 复制代码
/* 传统 :focus - 总是显示 */
button:focus {
  outline: 2px solid blue;
}

/* 现代 :focus-visible - 智能显示 */
button:focus-visible {
  outline: 2px solid blue;
}
css 复制代码
/* 最佳实践:同时使用 :focus 和 :focus-visible */
.button {
  /* 基础样式 */
}

/* 为不支持 :focus-visible 的浏览器提供基础焦点样式 */
.button:focus {
  outline: 2px solid blue;
}

/* 为现代浏览器提供智能焦点样式 */
.button:focus:not(:focus-visible) {
  outline: none; /* 移除不必要的焦点样式 */
}

.button:focus-visible {
  outline: 2px solid blue;
  /* 可以添加更丰富的焦点样式 */
  box-shadow: 0 0 0 4px rgba(0, 123, 255, 0.25);
}

使用场景建议

适合使用 :focus-visible

按钮、链接等交互元素

导航菜单

表单控件

自定义组件

可能需要使用 :focus

需要始终显示焦点的特殊组件

模态对话框中的焦点管理

自定义键盘导航系统
See the Pen 使用 :focus-visible 改善用户体验 by liu874396180 ( @liu874396180) on CodePen.

相关推荐
IT_陈寒25 分钟前
React 18并发渲染实战:5个核心API让你的应用性能飙升50%
前端·人工智能·后端
科普瑞传感仪器37 分钟前
从轴孔装配到屏幕贴合:六维力感知的机器人柔性对位应用详解
前端·javascript·数据库·人工智能·机器人·自动化·无人机
n***F87542 分钟前
SpringMVC 请求参数接收
前端·javascript·算法
wordbaby1 小时前
搞不懂 px、dpi 和 dp?看这一篇就够了:图解 RN 屏幕适配逻辑
前端
程序员爱钓鱼1 小时前
使用 Node.js 批量导入多语言标签到 Strapi
前端·node.js·trae
鱼樱前端1 小时前
uni-app开发app之前提须知(IOS/安卓)
前端·uni-app
V***u4531 小时前
【学术会议论文投稿】Spring Boot实战:零基础打造你的Web应用新纪元
前端·spring boot·后端
izx8882 小时前
HTML5敲击乐 PART--1
css
i听风逝夜2 小时前
Web 3D地球实时统计访问来源
前端·后端
iMonster2 小时前
React 组件的组合模式之道 (Composition Pattern)
前端