ARIA 初认识

2024-03-07 03:40
文章标签 认识 aria

本文主要是介绍ARIA 初认识,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

ARIA - Accessible Rich Internet Application
可访问的富互联网应用程序 - 使残疾人更容易访问 web 内容和 web 应用程序
 
ARIA 是唯一一种可以添加可访问帮助或说明文本的方式
 
Aria best practice : https://www.w3.org/WAI/ARIA/apg/patterns/
 

 aria-label

aria-label 标签来为辅助设备提供相应的标识来告诉它这个 button 是 close 的作用。

1

<button aria-label="Close" onclick="myDialog.close()">X</button>

https://www.aditus.io/aria/aria-label/ 

aria-labelledby

aria-labelledby 属性用来表明某些元素的 id 是某一对象的标签。它被用来确定控件或控件组与它们标签之间的联系。

<div id="billing">Billing Address</div><br><br><div><br>    <div id="name">Name</div><br>    <input type="text" aria-labelledby="name billing"/><br></div><br><div><br>    <div id="address">Address</div><br>    <input type="text" aria-labelledby="address billing"/><br></div><br><br>标题元素被与它们作为标题的内容联结在一起

<div role="main" aria-labelledby="foo">

    <h1 id="foo">Wild fires spread across the San Diego Hills</h1>

    Strong winds expand fires ignited by high temperatures ...

</div>

单选组radiogroup的容器通过一个 aria-labeledby 属性与他的的标签相联结

<div id="radio_label">My radio label</div>

<ul role="radiogroup" aria-labelledby="radio_label">

    <li role="radio">Item #1</li>

    <li role="radio">Item #2</li>

    <li role="radio">Item #3</li>

</ul>

标记对话框的标题元素通过 aria-labeledby 属性被引用

<div role="dialog" aria-labelledby="dialogheader">

    <h2 id="dialogheader">Choose a File</h2>

    ... Dialog contents

</div>

一个popup menu通过 aria-labeledby 属性与其标签相联结

<div role="menubar">

    <div role="menuitem" aria-haspopup="true" id="fileMenu">File</div>

    <div role="menu" aria-labelledby="fileMenu">

        <div role="menuitem">Open</div>

        <div role="menuitem">Save</div>

        <div role="menuitem">Save as ...</div>

        ...

    </div>

    ...

</div>

aria-hidden

把 aria-hidden="true" 加到元素上会把该元素和它的所有子元素从无障碍树上移除, 提升使用辅助技术的用户体验:

  • 纯装饰性的内容,如图标、图片
  • 重复的内容,如重复的文本
  • 屏幕外或被折叠的内容,如菜单

  • aria-hidden="true" 会把整个元素从无障碍 API 中移除
  • role="presentation" 和role="none" 会将元素从语义上移除,仍然会将元素暴露给辅助技术。

为了避免屏幕识读设备抓取非故意的和可能产生混淆的输出内容(尤其是当图标纯粹作为装饰用途时),我们为这些图标设置了 aria-hidden=“true” 属性。

https://developer.mozilla.org/zh-CN/docs/Web/Accessibility/ARIA/Attributes/aria-labelledby

Accessiblity Examples:

 

 

 

 

这篇关于ARIA 初认识的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Java架构师知识体认识

源码分析 常用设计模式 Proxy代理模式Factory工厂模式Singleton单例模式Delegate委派模式Strategy策略模式Prototype原型模式Template模板模式 Spring5 beans 接口实例化代理Bean操作 Context Ioc容器设计原理及高级特性Aop设计原理Factorybean与Beanfactory Transaction 声明式事物

每天认识几个maven依赖(ActiveMQ+activemq-jaxb+activesoap+activespace+adarwin)

八、ActiveMQ 1、是什么? ActiveMQ 是一个开源的消息中间件(Message Broker),由 Apache 软件基金会开发和维护。它实现了 Java 消息服务(Java Message Service, JMS)规范,并支持多种消息传递协议,包括 AMQP、MQTT 和 OpenWire 等。 2、有什么用? 可靠性:ActiveMQ 提供了消息持久性和事务支持,确保消

认识、理解、分类——acm之搜索

普通搜索方法有两种:1、广度优先搜索;2、深度优先搜索; 更多搜索方法: 3、双向广度优先搜索; 4、启发式搜索(包括A*算法等); 搜索通常会用到的知识点:状态压缩(位压缩,利用hash思想压缩)。

SpringMVC-1.认识及配置

SpringMVC是一个基于请求驱动的Web框架,和structs一样是目前最优秀的基于MVC框架,现在的项目一般都使用SpringMVC代替Structs。 MVC模式中,Model是应用程序中用于处理应用程序数据逻辑的部分,通常模型对象在数据库中存取数据。View是应用程序中处理数据显示的部分,通常视图是依据模型数据创建。Controller是应用程序中处理用户交互的部分。通常控制器负责从视

【H2O2|全栈】关于HTML(1)认识HTML

HTML相关知识 目录 前言 准备工作 WEB前端是什么? HTML是什么? 如何运行HTML文件? 标签 概念 分类 双标签和单标签 行内标签和块标签 HTML文档结构 预告和回顾 UI设计相关 Markdown | Md文档相关  项目合作管理相关  后话 前言 本系列的博客将分享前端HTML的相关知识点。 本篇作为本系列的第一期博客,主要讲解H

认识鬼火引擎

一、Irrlicht简介 (1)概念Irrlicht引擎是一个用C++书写的高性能实时3D引擎,可以应用于C++程序或者.NET语言中。通过使用Direct3D(Windows平台)、OpenGL 或它自己的软件着色程序,可以实现该引的完​全跨平台。尽管是开源的,该Irrlicht库提供了可以在商业级的3D引擎上具有的艺术特性,例如动态的阴影,粒子系统,角色动画,室内和室外技术以及碰撞检测等。(

Jenkins--pipeline认识及与RF文件的结合应用

什么是pipeline? Pipeline,就是可运行在Jenkins上的工作流框架,将原本独立运行的单个或多个节点任务连接起来,实现单个任务难以完成的复杂流程编排与可视化。 为什么要使用pipeline? 1.流程可视化显示 2.可自定义流程任务 3.所有步骤代码化实现 如何使用pipeline 首先需要安装pipeline插件: 流水线有声明式和脚本式的流水线语法 流水线结构介绍 Node:

git:认识git和基本操作(1)

目录 一、版本控制器 1.安装git 2.创建git本地仓库 3.配置git 二、git操作(1) 1.工作区、暂存区、版本库 2.添加文件 3.查看.git 4.修改文件 一、版本控制器         所谓的版本控制器,就是能让你了解到每一个文件的修改历史。相应的,在企业级开发中,用来记录一个工程的每一次改动和管理版本迭代,同时方便多人协作开发。         g

关于MANIFEST.MF的内容认识

文章来源 https://baike.baidu.com/item/MANIFEST.MF https://www.cnblogs.com/Gandy/p/7290069.html 一、百度百科关于MANIFEST.MF文件介绍 打开Java的JAR文件我们经常可以看到文件中包含着一个META-INF目录,这个目录下会有一些文件,其中必有一个MANIFEST.MF,这个文件描述了

C++---由优先级队列认识仿函数

文章目录 一、优先级队列是什么? 二、如何使用优先级队列 1、优先级队列容器用法 2、为什么容器本身无序? 三、什么是仿函数? 1. 什么是仿函数? 2. 仿函数的优势 四、仿函数如何使用? 1、重载operator()函数 2、运用第三个参数模板 3、大小堆切换  大堆测试代码: 小堆测试代码: 4、头文件总代码  五、什么是容器适配器? 前言   本文主要介绍了优先级队列是什