焦点管理:`outline` 与 `:focus-visible` 的无障碍考量

聚光灯下的舞者:关于 outline 与 :focus-visible 的一场无障碍芭蕾 我们每天都在和代码打交道,创造着虚拟世界,而这个世界理应是属于每个人的,无论他们的身体状况如何。然而,在构建这个世界的过程中,我们常常会忘记那些需要特殊关照的群体,比如依赖键盘操作的用户、视力障碍人士等等。焦点管理,尤其是 outline 和 :focus-visible 这两个小小的CSS属性,就如同舞台上的聚光灯,决定了哪些舞者能够被观众看到,哪些舞者只能默默地站在黑暗中。 初学前端的时候,outline 绝对是会被嫌弃的对象。它总是那么的“直男”,粗暴地在元素周围画一个框,丑陋又突兀,和精心设计的UI格格不入。于是,我们迫不及待地用 outline: none; 将它抹杀,世界瞬间清净了,仿佛一切都变得更美好了。 然而,这种“美”是建立在牺牲部分用户体验的基础上的。想象一下,一个只使用键盘浏览网页的用户,他们没有鼠标,只能通过Tab键来切换焦点。如果页面上所有元素的 outline 都被移除了,他们就像在黑暗中摸索,根本不知道当前焦点在哪里。这种感觉就像在空旷的房间里玩捉迷藏,你永远不知道下 …