浅析HTML5 Landmark
Landmark 是一种用来表示网页组织结构的方法。通常一个网页可以被切分成几个大块 以一个视频网站为例,网页的最上方是一条banner,左侧是一个导航栏,右侧显示视频。网页可以通过这种切分方式来分割出不同的功能区。当然在一个功能区内也可以递归地进行切分,这里先不展开。 如何使用 Landmark 事实上,在HTML5 landmark出现之前,就已经有landmark的概念了。 而在HTML5中定义了一些全新的标签,并赋予他们隐式的landmark语义。
HTML Element
Landmark Role
这些标签本身就隐含着landmark的含义,也就是说<main>和<div role="main">是完全等价的。 对于search landmark没有定义专用的HTML标签,通常使用<form role="search">来实现。 也就是说,在上一节引用的网页中 对于1号区域,应当把所有的内容放到一个<header></header>中,标识该部分是banner 对于2号区域,应当把所有的内容放到一个<nav></nav>中,标识该部分是导航栏 对于3号区域,应当把所有的内容放到一个<main></main>中,标识该部分是网页的主要内容 读屏软件会生成一系列的跳转链接来帮助视力障碍者确定网页的结构并迅速跳转至需要的部分。 在HTML5之前,只能通过role属性来定义landmark,HTML5推出的新标签能够在保持可访问性的情况下简化标记。但并不是每个用户使用的辅助工具都支持最新的标准,因此许多教程推荐使用<main role="main">的写法来同时兼容两种标准。W3C的标准不鼓励在已经含有隐式语义的情况下使用role属性,因为两者语义冲突的情况下可能导致无法预计的表现。 区分同类型的 Landmark 有时候页面中可能会有多个导航栏,分别有不同的作用。比如一个电商网站有一个主导航来跳转到购物车、收藏夹等不同的页面;还有一个产品导航来跳转到电子产品、婴儿产品。如何对两者进行区分呢,这里需要使用aria-label或者aria-labelledby属性。 <nav aria-label="主导航"> <ul> <li>主页</li> <li>购物车</li> <li>收藏夹</li> </ul> </div> <nav aria-label="产品导航"> <ul> <li>婴儿产品</li> <li>电子产品</li> <li>体育产品</li> </ul> </div> 这样读屏软件会分别生成以下两个链接 导航,主导航 导航,产品导航 这样就将不同的landmark区分开了。 使用读屏软件读取 Landmark 为了更好地理解landmark,我尝试使用读屏软件来测试网页上的landmark。这里我使用的是Windows系统自带的讲述人。 按下Caps Lock + F5来显示网页中所有的landmark。 按下Caps Lock + N,可以看到讲述人光标移动到了网页的主要内容部分。 使用D或Shift + D可以在landmark间切换,同时会朗读出每个landmark的信息。 总结 和单词的原意一样,landmark就像是一个网页的许多个“入口”或“地标”。通过landmark标注网页结构的信息,可以帮助视力障碍者通过读屏软件了解网页的结构,并迅速到达需要的部分。 (编辑:威海站长网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |