前端无障碍性:让所有人都能使用你的网站

前端无障碍性:让所有人都能使用你的网站

毒舌时刻

前端无障碍性?这不是给残障人士用的吗?

"我的网站不需要无障碍性,用户都是正常人"——结果被投诉歧视,
"无障碍性太麻烦了,我没时间做"——结果失去了一部分用户,
"无障碍性就是加几个alt标签而已"——结果网站在屏幕阅读器下完全不可用。

醒醒吧,无障碍性不是慈善,而是一种责任!

为什么你需要这个?

  • 法律合规:许多国家和地区都有无障碍性法规
  • 扩大用户群体:让残障人士也能使用你的网站
  • SEO优化:无障碍性好的网站更容易被搜索引擎收录
  • 用户体验:对所有人都友好的设计,对正常人也有好处

反面教材

<!-- 反面教材:缺乏语义化HTML --> <div> <div>网站logo</div> <div> <div>首页</div> <div>关于我们</div> <div>联系我们</div> </div> </div> <!-- 反面教材:缺少alt标签 --> <img src="logo.png"> <!-- 反面教材:颜色对比不足 --> <div>这段文字很难阅读</div> <!-- 反面教材:键盘无法访问 --> <button onclick="doSomething()">点击我</button> <!-- 反面教材:缺少ARIA属性 --> <div> <div> <h2>弹窗标题</h2> <p>弹窗内容</p> </div> </div> 

正确的做法

<!-- 正确的做法:使用语义化HTML --> <header> <h1>网站logo</h1> <nav> <ul> <li><a href="/">首页</a></li> <li><a href="/about">关于我们</a></li> <li><a href="/contact">联系我们</a></li> </ul> </nav> </header> <!-- 正确的做法:添加alt标签 --> <img src="logo.png" alt="网站logo"> <!-- 正确的做法:足够的颜色对比 --> <div>这段文字很容易阅读</div> <!-- 正确的做法:键盘可访问 --> <button onclick="doSomething()" tabindex="0">点击我</button> <!-- 正确的做法:添加ARIA属性 --> <div role="dialog" aria-labelledby="modal-title" aria-hidden="true"> <div> <h2>弹窗标题</h2> <p>弹窗内容</p> </div> </div> <!-- 正确的做法:使用ARIA live region --> <div aria-live="polite"></div> <script> // 正确的做法:键盘导航 document.addEventListener('keydown', function(e) { if (e.key === 'Tab') { // 确保焦点在可见元素上 document.body.classList.add('keyboard-navigation'); } }); // 正确的做法:跳过导航链接 function createSkipLink() { const skipLink = document.createElement('a'); skipLink.href = '#main-content'; skipLink.className = 'skip-link'; skipLink.textContent = '跳过导航'; document.body.insertBefore(skipLink, document.body.firstChild); } // 正确的做法:表单标签关联 function associateLabels() { const inputs = document.querySelectorAll('input'); inputs.forEach(input => { if (input.id) { const label = document.querySelector(`label[for="${input.id}"]`); if (label) { // 标签和输入框已关联 } } }); } // 正确的做法:动态内容通知 function updateStatus(message) { const statusElement = document.getElementById('status-message'); statusElement.textContent = message; } </script> <style> /* 正确的做法:焦点样式 */ *:focus { outline: 2px solid #0066cc; outline-offset: 2px; } /* 正确的做法:跳过链接样式 */ .skip-link { position: absolute; top: -40px; left: 0; background: #0066cc; color: white; padding: 8px; z-index: 100; } .skip-link:focus { top: 0; } /* 正确的做法:键盘导航样式 */ .keyboard-navigation *:focus { /* 更明显的焦点样式 */ } </style> 

毒舌点评

看看,这才叫前端无障碍性!不是简单地加几个alt标签,而是从语义化HTML、键盘导航、ARIA属性等多个方面入手。

记住,无障碍性不是额外的工作,而是前端开发的基本要求。一个真正优秀的前端开发者,会把无障碍性融入到日常开发中。

所以,别再觉得无障碍性不重要了,它是你作为开发者的责任!

总结

  • 语义化HTML:使用正确的HTML标签,如header、nav、main、section等
  • alt标签:为所有图片添加有意义的alt属性
  • 颜色对比:确保文本和背景的对比度足够高
  • 键盘导航:确保所有功能都可以通过键盘访问
  • ARIA属性:使用ARIA角色和属性增强可访问性
  • 焦点管理:确保焦点在正确的元素上,并有明显的焦点样式
  • 跳过导航:为屏幕阅读器用户提供跳过重复内容的链接
  • 表单标签:确保所有表单元素都有关联的标签
  • 动态内容:使用ARIA live region通知屏幕阅读器动态内容的变化
  • 测试:使用屏幕阅读器和无障碍性测试工具进行测试

无障碍性,让你的网站对所有人都友好!

Read more

【征文计划】AR健身教练:形随心动 - 基于Rokid CXR-M SDK的实践落地

【征文计划】AR健身教练:形随心动 - 基于Rokid CXR-M SDK的实践落地

一、项目背景与创意起源 在当今快节奏的都市生活中,健身已成为许多人保持健康的重要方式。然而,居家健身面临一个普遍痛点:缺乏专业指导,容易因动作不规范导致运动损伤,同时低头看手机或平板的体验也大大降低了健身的沉浸感和效率。 根据《2024年中国健身行业白皮书》显示,超过65%的居家健身用户表示"缺乏专业指导"是他们放弃健身的主要原因。而Rokid Glasses作为一款轻量级AR眼镜,其独特的"抬头即见"交互方式,为解决这一问题提供了绝佳的硬件基础。 "形随心动"创意的诞生源于一个简单但关键的观察:如果能将专业教练"投射"到用户视野中,实时指导动作,同时提供直观的数据反馈,那么居家健身体验将发生质的飞跃。通过Rokid CXR-M SDK的AI场景、自定义页面和提词器功能,我们能够实现这一愿景。 二、Rokid CXR-M SDK 相关 1. Rokid

喂饭级教程:OpenClaw 对接 QQ 机器人,本地/腾讯云都能用

喂饭级教程:OpenClaw 对接 QQ 机器人,本地/腾讯云都能用

文章目录 * 前言 * 一、选对路子:官方 Bot 还是个人号? * 方案 A:QQ 开放平台官方机器人 * 方案 B:个人 QQ 号变身机器人 * 二、环境准备:5 分钟搞定基础设施 * 1. 服务器/电脑要求 * 2. 安装 OpenClaw * 3. 配置大模型 API * 三、方案 A:对接 QQ 开放平台官方机器人 * Step 1:注册开发者并创建机器人 * Step 2:获取三件套凭证 * Step 3:配置 IP 白名单和沙箱 * Step 4:OpenClaw 端配置

AI 辅助开发实战:基于树莓派智能家居毕设的高效构建与避坑指南

在基于树莓派的智能家居毕业设计中,很多同学都遇到过相似的困境:树莓派算力有限,跑个复杂的AI模型就卡顿;传感器数据五花八门,处理起来容易出错;想把模型部署到边缘端,步骤繁琐,调试过程更是让人头大。整个项目就像在走钢丝,既要保证功能,又要兼顾性能和稳定性。 最近,我尝试将AI辅助开发工具和轻量级AI推理框架结合起来,重新梳理了整个开发流程,发现效率提升非常明显。这篇文章,我就来分享一下如何利用这些工具,高效、稳定地构建一个智能家居毕设系统,并附上一些实践中总结的“避坑”经验。 1. 背景与核心痛点:为什么需要AI辅助开发? 传统的树莓派智能家居项目开发,通常有几个绕不开的难题: * 硬件资源捉襟见肘:树莓派(尤其是Zero或3B+等型号)的内存和CPU性能有限。直接部署未经优化的TensorFlow或PyTorch模型,很容易导致系统响应迟缓甚至崩溃。 * 模型部署“从入门到放弃”:将PC上训练好的模型移植到ARM架构的树莓派上,涉及框架版本、依赖库、算子兼容性等一系列问题,环境配置就能耗掉大量时间。 * 调试过程“黑盒”化:当系统集成传感器、执行器、网络服务和AI推理后,

[论文阅读] AI + 软件工程 | 突破LLM代码生成瓶颈:编程知识图谱(PKG)让检索增强更精准

[论文阅读] AI + 软件工程 | 突破LLM代码生成瓶颈:编程知识图谱(PKG)让检索增强更精准

突破LLM代码生成瓶颈:编程知识图谱(PKG)让检索增强更精准 论文信息 * 原标题:Context-Augmented Code Generation Using Programming Knowledge Graphs(基于编程知识图谱的上下文增强代码生成) * 主要作者及研究机构: * Shahd Seddik、Fahd Seddik、Iman Saberi、Fatemeh Fard(加拿大不列颠哥伦比亚大学) * Minh Hieu Huynh、Patanamon Thongtanunam(澳大利亚墨尔本大学) * 引文格式(GB/T 7714): Seddik S, Seddik F, Saberi I, et al. Context-Augmented Code Generation Using Programming Knowledge Graphs[J]