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

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

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

/* 现代 :focus-visible - 智能显示 */
button:focus-visible {
  outline: 2px solid blue;
}
/* 最佳实践:同时使用 :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.
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

网开三面

你的鼓励将是我创造的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值