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

本文主要是介绍《移动网页设计与开发 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年的浏览器(我所知道的)中都已经实现,所以,除非使用一个非常旧的或一个非常基本的浏览器,否则确切属性值选择符就是有用—但请注意,复杂选择符可能对页面下载速度有不利的影响。

这篇关于《移动网页设计与开发 HTML5+CSS3+JavaScript》—— 2.2 网页易读性倡议的无障碍的富因特网应用程序组件(WAI-ARIA)...的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/830487

相关文章

JSON字符串转成java的Map对象详细步骤

《JSON字符串转成java的Map对象详细步骤》:本文主要介绍如何将JSON字符串转换为Java对象的步骤,包括定义Element类、使用Jackson库解析JSON和添加依赖,文中通过代码介绍... 目录步骤 1: 定义 Element 类步骤 2: 使用 Jackson 库解析 jsON步骤 3: 添

Java中注解与元数据示例详解

《Java中注解与元数据示例详解》Java注解和元数据是编程中重要的概念,用于描述程序元素的属性和用途,:本文主要介绍Java中注解与元数据的相关资料,文中通过代码介绍的非常详细,需要的朋友可以参... 目录一、引言二、元数据的概念2.1 定义2.2 作用三、Java 注解的基础3.1 注解的定义3.2 内

Java中使用Java Mail实现邮件服务功能示例

《Java中使用JavaMail实现邮件服务功能示例》:本文主要介绍Java中使用JavaMail实现邮件服务功能的相关资料,文章还提供了一个发送邮件的示例代码,包括创建参数类、邮件类和执行结... 目录前言一、历史背景二编程、pom依赖三、API说明(一)Session (会话)(二)Message编程客

Java中List转Map的几种具体实现方式和特点

《Java中List转Map的几种具体实现方式和特点》:本文主要介绍几种常用的List转Map的方式,包括使用for循环遍历、Java8StreamAPI、ApacheCommonsCollect... 目录前言1、使用for循环遍历:2、Java8 Stream API:3、Apache Commons

JavaScript中的isTrusted属性及其应用场景详解

《JavaScript中的isTrusted属性及其应用场景详解》在现代Web开发中,JavaScript是构建交互式应用的核心语言,随着前端技术的不断发展,开发者需要处理越来越多的复杂场景,例如事件... 目录引言一、问题背景二、isTrusted 属性的来源与作用1. isTrusted 的定义2. 为

Java循环创建对象内存溢出的解决方法

《Java循环创建对象内存溢出的解决方法》在Java中,如果在循环中不当地创建大量对象而不及时释放内存,很容易导致内存溢出(OutOfMemoryError),所以本文给大家介绍了Java循环创建对象... 目录问题1. 解决方案2. 示例代码2.1 原始版本(可能导致内存溢出)2.2 修改后的版本问题在

Java CompletableFuture如何实现超时功能

《JavaCompletableFuture如何实现超时功能》:本文主要介绍实现超时功能的基本思路以及CompletableFuture(之后简称CF)是如何通过代码实现超时功能的,需要的... 目录基本思路CompletableFuture 的实现1. 基本实现流程2. 静态条件分析3. 内存泄露 bug

四种Flutter子页面向父组件传递数据的方法介绍

《四种Flutter子页面向父组件传递数据的方法介绍》在Flutter中,如果父组件需要调用子组件的方法,可以通过常用的四种方式实现,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录方法 1:使用 GlobalKey 和 State 调用子组件方法方法 2:通过回调函数(Callb

Java中Object类的常用方法小结

《Java中Object类的常用方法小结》JavaObject类是所有类的父类,位于java.lang包中,本文为大家整理了一些Object类的常用方法,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1. public boolean equals(Object obj)2. public int ha

SpringBoot项目中Maven剔除无用Jar引用的最佳实践

《SpringBoot项目中Maven剔除无用Jar引用的最佳实践》在SpringBoot项目开发中,Maven是最常用的构建工具之一,通过Maven,我们可以轻松地管理项目所需的依赖,而,... 目录1、引言2、Maven 依赖管理的基础概念2.1 什么是 Maven 依赖2.2 Maven 的依赖传递机