《移动网页设计与开发 HTML5+CSS3+JavaScript》—— 2.2 网页易读性倡议的无障碍的富因特网应用程序组件(WAI-ARIA)

简介:

本节书摘来异步社区《移动网页设计与开发 HTML5+CSS3+JavaScript》一书中的第2章,第2.2节,作者:【英】Peter Gasston,更多章节内容可以访问云栖社区“异步社区”公众号查看。

2.2 网页易读性倡议的无障碍的富因特网应用程序组件(WAI-ARIA)

创建网页易读性倡议的无障碍的富因特网应用程序(Accessible Rich Internet Applications)组件(WAI-ARIA)的目的,就是为了解决可访问性的短缺。随着网络超越简单的文档标记,进入一个应用和交互的时代,可访问性短缺就产生了。

下面,我们来看看WAI-ARIA是如何做到这一点的。首先,创建一些HTML扩展(或者,事实上任何基于DOM语言的扩展都可以,例如SVG和XML的扩展);其次,允许开发人员开发能识别交互式内容的浏览器和辅助技术。例如,如果有一个链接,单击它时,就会使用JavaScript创建一个屏幕上的对话框叠加,但没有办法让浏览器识别它;这个标记看起来就像一个标准的链接:

7f66d93404dd03979ea1e3b0d6255cad8fe7878a

因为事件附加在使用脚本的链接上,所以,对于这里发生的事件,屏幕阅读设备没有任何信息,也就不能告诉用户事件的来龙去脉,用户对该事件仍然一无所知。WAI- ARIA引入一个新属性—aria-haspopup,只要出现上述的情况,它就会告诉用户到底发生了什么:

76d4904aa09f80048daec777f51280f1b2145592

用户可以使用一系列的新属性,其中之一,就是所谓的landmark role。这些属性能使得屏幕阅读器和其他可访问导航设备能识别页面结构,这样的话,用户就可以轻松地找到文档。在某种程度上,这种解决方案履行了结构职责,而结构职责,本应是新创造的HTML5元素所应该履行的。

注释:
如前所述,眼下,一些用户代理和辅助技术不能正确解析新HTML5文档大纲,所以,使用landmark role可能会对提高向后兼容性有所帮助。
landmark role的应用使用了具有一系列预先定义值的role属性。这些值并不直接对应HTML5的结构元素,但它们大多都非常的相配。比方说,如果想要定义包含网站一般信息的文档区域,例如标识和品牌标语,则需添加banner:

938ff975dfe4a6772fcf7576a1df392a9295069c

banner大致类似于header元素,并且在大多数情况下,可以用它来代替header元素。

一些landmark role在HTML5中并没有对应物。在HTML5中,没有合适的元素来指明网页的主要内容在哪里,所以,要想让屏幕阅读器知道关键内容的位置,我们可以使用main:

6bb67943ee38b2a7a0328ea8b79abe2aae3b7918

WAI-ARIA规范所定义的8个landmark role:

application 显示页面的一个区域,这个页面是一个交互式应用程序,而不是一个文档。

banner 正如前面提到的,说明一般的网站内容,可能包含在标头中;在这种情况下,类似于header元素。

complementary 显示主要内容的相关内容,而不是主要内容的组成部分,像一个侧边栏;它类似于aside元素。

contentinfo 提供法律指令等文档信息。通常位于页脚,所以,在这种情况下类似于footer元素。

form 显示除搜索之外的任何形式,例如,联系人表单。

main 显示文档的核心内容。

navigation 包含导航这些文件或相关文件的链接组,类似于nav。

search 显示专门用来搜索这个网站或其他网站的格式。

landmark role不但可用于导航,而且有助于提供语义值,它还能为CSS制作便捷的样式钩子(hook)。使用确切属性值选择符(Exact Attribute Value Selector),就可以轻松地应用规则,例如,用在页眉中:

4764fb5ead72f2474d3d6360bba6339096d37d77

这个选择符几乎在所有过去10年的浏览器(我所知道的)中都已经实现,所以,除非使用一个非常旧的或一个非常基本的浏览器,否则确切属性值选择符就是有用—但请注意,复杂选择符可能对页面下载速度有不利的影响。

相关文章
|
7月前
|
JSON 自然语言处理 前端开发
【01】对APP进行语言包功能开发-APP自动识别地区ip后分配对应的语言功能复杂吗?-成熟app项目语言包功能定制开发-前端以uniapp-基于vue.js后端以laravel基于php为例项目实战-优雅草卓伊凡
【01】对APP进行语言包功能开发-APP自动识别地区ip后分配对应的语言功能复杂吗?-成熟app项目语言包功能定制开发-前端以uniapp-基于vue.js后端以laravel基于php为例项目实战-优雅草卓伊凡
355 72
【01】对APP进行语言包功能开发-APP自动识别地区ip后分配对应的语言功能复杂吗?-成熟app项目语言包功能定制开发-前端以uniapp-基于vue.js后端以laravel基于php为例项目实战-优雅草卓伊凡
|
9月前
|
人工智能 程序员 UED
【01】完成新年倒计时页面-蛇年新年快乐倒计时领取礼物放烟花html代码优雅草科技央千澈写采用html5+div+CSS+JavaScript-优雅草卓伊凡-做一条关于新年的代码分享给你们-为了C站的分拼一下子
【01】完成新年倒计时页面-蛇年新年快乐倒计时领取礼物放烟花html代码优雅草科技央千澈写采用html5+div+CSS+JavaScript-优雅草卓伊凡-做一条关于新年的代码分享给你们-为了C站的分拼一下子
399 21
【01】完成新年倒计时页面-蛇年新年快乐倒计时领取礼物放烟花html代码优雅草科技央千澈写采用html5+div+CSS+JavaScript-优雅草卓伊凡-做一条关于新年的代码分享给你们-为了C站的分拼一下子
|
8月前
|
前端开发
【2025优雅草开源计划进行中01】-针对web前端开发初学者使用-优雅草科技官网-纯静态页面html+css+JavaScript可直接下载使用-开源-首页为优雅草吴银满工程师原创-优雅草卓伊凡发布
【2025优雅草开源计划进行中01】-针对web前端开发初学者使用-优雅草科技官网-纯静态页面html+css+JavaScript可直接下载使用-开源-首页为优雅草吴银满工程师原创-优雅草卓伊凡发布
229 1
【2025优雅草开源计划进行中01】-针对web前端开发初学者使用-优雅草科技官网-纯静态页面html+css+JavaScript可直接下载使用-开源-首页为优雅草吴银满工程师原创-优雅草卓伊凡发布
|
9月前
|
前端开发 JavaScript
【02】v1.0.1更新增加倒计时完成后的放烟花页面-优化播放器-优化结构目录-蛇年新年快乐倒计时领取礼物放烟花html代码优雅草科技央千澈写采用html5+div+CSS+JavaScript-优雅草卓伊凡-做一条关于新年的代码分享给你们-为了C站的分拼一下子
【02】v1.0.1更新增加倒计时完成后的放烟花页面-优化播放器-优化结构目录-蛇年新年快乐倒计时领取礼物放烟花html代码优雅草科技央千澈写采用html5+div+CSS+JavaScript-优雅草卓伊凡-做一条关于新年的代码分享给你们-为了C站的分拼一下子
236 14
【02】v1.0.1更新增加倒计时完成后的放烟花页面-优化播放器-优化结构目录-蛇年新年快乐倒计时领取礼物放烟花html代码优雅草科技央千澈写采用html5+div+CSS+JavaScript-优雅草卓伊凡-做一条关于新年的代码分享给你们-为了C站的分拼一下子
|
10月前
|
JavaScript 前端开发
页面滚动触发css3动画js插件
delighters.js是一款页面滚动触发css3动画js插件。该js插件可以在页面向下滚动时,为进入浏览器视口的元素制作各种炫酷的CSS3动画效果。
139 13
|
10月前
|
Web App开发 JavaScript 前端开发
Node.js开发
Node.js开发
210 13
|
10月前
纸屑飘落生日蛋糕场景js+css3动画特效
纸屑飘落生日蛋糕CSS3动画特效是一款js+css3制作的全屏纸屑飘落,生日蛋糕点亮庆祝动画特效。
132 3
|
10月前
|
Web App开发 移动开发 HTML5
html5 + Three.js 3D风雪封印在棱镜中的梅花鹿动效源码
html5 + Three.js 3D风雪封印在棱镜中的梅花鹿动效源码。画面中心是悬浮于空的梅花鹿,其四周由白色线段组成了一个6边形将中心的梅花鹿包裹其中。四周漂浮的白雪随着多边形的转动而同步旋转。建议使用支持HTML5与css3效果较好的火狐(Firefox)或谷歌(Chrome)等浏览器预览本源码。
214 2

热门文章

最新文章

  • 1
    【CSS】前端三大件之一,如何学好?从基本用法开始吧!(六):全方面分析css的Flex布局,从纵、横两个坐标开始进行居中、两端等元素分布模式;刨析元素间隔、排序模式等
  • 2
    【CSS】前端三大件之一,如何学好?从基本用法开始吧!(五):背景属性;float浮动和position定位;详细分析相对、绝对、固定三种定位方式;使用浮动并清除浮动副作用
  • 3
    【CSS】前端三大件之一,如何学好?从基本用法开始吧!(八):学习transition过渡属性;本文学习property模拟、duration过渡时间指定、delay时间延迟 等多个参数
  • 4
    【CSS】前端三大件之一,如何学好?从基本用法开始吧!(一):CSS发展史;CSS样式表的引入;CSS选择器使用,附带案例介绍
  • 5
    【CSS】前端三大件之一,如何学好?从基本用法开始吧!(四):元素盒子模型;详细分析边框属性、盒子外边距
  • 6
    【CSS】前端三大件之一,如何学好?从基本用法开始吧!(二):CSS伪类:UI伪类、结构化伪类;通过伪类获得子元素的第n个元素;创建一个伪元素展示在页面中;获得最后一个元素;处理聚焦元素的样式
  • 7
    React 中如何安装与使用 Tailwind CSS
  • 8
    【CSS】前端三大件之一,如何学好?从基本用法开始吧!(七):学习ransform属性;本文学习 rotate旋转、scale缩放、skew扭曲、tanslate移动、matrix矩阵 多个参数
  • 9
    (CSS)使用Flex布局,帮助你快速了解各种基本的Flex布局属性以及帮你让元素快速达到布局中的指定位置!
  • 10
    【CSS】前端三大件之一,如何学好?从基本用法开始吧!(九):强势分析Animation动画各类参数;从播放时间、播放方式、播放次数、播放方向、播放状态等多个方面,完全了解CSS3 Animation