版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、张鑫旭在其个人网站上发表了一篇文章JS下拉菜单实现与可访问性问题的一些思 考,文中为我们分享了他对于 JS下拉菜单实现与可访问性问题的一些思考及实际经验, 现转载于此,供大家借鉴学习。 全文如下:一、俗耐的开篇语关于下拉菜单的可用性问题,我之前一直都是忽略的,可以说是不知道,常常仅仅止步于眼前的效果上。前段时间看到了Roger的Accessing Nav Drop-Downs”一文,就是讲了下下拉菜单的可用性问题。同时,巧的是,最近在看淘宝UED翻译的ppk谈JavaScript一书,其多次提到了可访问性的问题,尤其在p28p37 对JavaScript 及其一些可用性问题发表了自己的看法。其
2、中主要的观点和注意事项与Roger的文章是一致的。这些阅读的经历让我意识到自己长时间忽略下拉菜单的可访问性,于是开始结合实际情况,思考自己以后需要注意和提高的地方。这让我对下拉菜单实现方式选择、标签的使用等有了更加明确的认识。 不太成熟的思考,仅用于交流。再具体讲述下拉菜单的可访问性之前, 先简单说说下拉菜单以及下拉菜单的实现吧。二、关于下拉菜单及其实现百度百科 对 下拉菜单”一词的解释是:以条形菜单栏和菜单栏中每个菜单项的弹出菜单窗口两部分组成,一般作为应用系统的主菜单使用。不过这段话就像盗梦空间一样,让人很难懂。通俗点讲,就是经过/会点击就会显示列表的菜单 ”就叫做下拉菜单。在 Web上非
3、常之常见,例如,我随便打开个页面,啊,就像是我浏览器现在显示的百科的页面的右 上角:或是隔壁的微博页面,啊,果然,看左上角的广场下拉:恩恩,看来下拉菜单就像是男人一样,满地都是。就不一一举例了,关于下拉菜单的实 现,那方法可就多了,class切换,属性绑定,js定位等,不同的页面,不同的设计,不同的架构,就有不同的实现方法。由于每个项目,每个页面的情况都不一样,所以,不能轻易 的下结论,你是大熊猫,是国宝,它是小野猫,是杂草。但是,就可用性而言,不同的方法 优劣还是有标准来评判的,这个在后面会自然而然的展示。现在,举个切换 class实现下拉效果的简单例子,实例菜单原型来自Mtime时光网,作
4、者注:Mtime创始人在新浪微博上很活跃,你有兴趣可以follow 他,马日拉,你有没有觉得这个名字很有遐想的空间呢?截图如下:此导航下拉的每个下拉内容都已经通过CSS定位好了,但是,考虑到加载的原因,其下拉内容默认是未装载的。也就是说,是鼠标移至导航内容上,才动态load下拉div并嵌入导航li标签内的,如下列图所示:El -clt closs-1til -ill class*noa-eH tcer= 2 v沪娥的科先*p:. mtV 时光5 p iirK|r;i:bpspnrt-zl a:ss=cai.n.lchild style=f; hidden;height;226px; disl*
5、5a当然,作为静态demo页面,没有必要动态load下拉内容,所以,demo页面的下拉 div默认就是隐藏且装载好的,于是,我们就可以通过简单的class切换实现下拉效果。ul xc= narigafionRegionJ首先是HTML结构,见下列图:tj title苣页|1花&11竝卩;/ :轴晒鬥廿11已 li token=2 elas5=+ hotS-SMT/c|i3on:-4nbsp;-;/5pnn-div style=oyerloA: hicen; hmigfit: 2ZEp冥:* 亡Idss= i_n_1 chllctSlhref* href* href= href* href hr
6、ef= href- href=h5xah5xd弋 h5Ktih5avh討ihZda11 tolcert-h3 class=,TCivih七七p: /nTmtime -comxefn class =rmylimek xJ R HYPERLINK ime ime, com/rno vie Am的电影 h-j:.cor/goip/=我的群组=cx/h5i-http;,匚口Ve.nbe/signin1-cen class=http: /wmw. rntime. ccm/member/si g ni n/?redi rectJpl=l ht p: /, .ntirie. coVne.nbe/si gni
7、n-edi rectUl=h七七:j! Hz.世i- /si .jnm,P?fleditUI=张鑫旭-鑫空间-養生活ht lp7/ HYPERLINK http:/www.zhsAg www.zhsAg x 由乂 at a tn核心CSS代码如下:.i_n _ldisplay:non e;.showtime_hover.i_n,.quiz_hover.i_n,.home_hover.i_n_l,.movie_hover.i_n,.tv_hover.i_n,.pers on _hover.i_n _l,.blog_hover.i_n,.group_hover .i_ndisplay:block;
8、可见,我们只要让li标签的class,例如 我的时光所在li标签,由” home变成” home_hover就可以控制下拉菜单的显示与隐藏了,很简单吧,所以,相应的js代表就会类似于下面:var o = docume nt.getEleme ntByld(” navigati on Regi on).getEleme ntsByTagName(li);3.var l=oen gth;4.for(vari=0; i然后,效果就如下列图所示,截自IE6浏览器:11首页我的时光电彫电视* All我的时光我需龛我的群爼我的博容一J您可以狠狠地点击这里:时光网下拉菜单demo恩,不错,效果良好,没有兼容
9、性问题,js代码也算是简洁易懂,开起来似乎大功告成。要是以前的我,估计也就会到这里就结束了,没有bug,测试工程师不会来找茬了。但是,实际上,此处下拉的可访问性只能说是中等及格的水平。作者注:不过貌似现在整个行业即使淘宝这类重视前端的公司的下拉菜单都只实现到这一程度,或许其中有着各种各样的原因,但我个人感觉还是整个行业的水平有待提高。为何说看似不错的下拉菜单效果其实可用性低呢?继续下文。三、下拉菜单可访问性问题首先答复这个问题:什么是可访问性?可访问性是指你的网页对任何人、在任何环境下都是可持续访问的。但是,在目前,要 使得所有的网站在任何情况下都保持完美无缺的可访问性,这样的要求比要求老板升
10、职还要高,是不实际的,但是,在有限的范围内,有着实际意义的,我们可以提高的地方还是很多 的。常见的可访问性问题有下面三个:无脚本这个主要是考虑到某些浏览器不支持JavaScript的情况。例如Google的页面中经常可见标签,其就考虑到这一点。但是,就我个人的观点,如果您的网站不是面对亚非拉美这些国家,无脚本的问题其实是可以忽略的。当然,某些人员故意禁用JavaScript 则另当别论。没有鼠标这是经常会遇到的。 有些用户不使用鼠标, 而是使用键盘,理由各种各样。例如我自己, 有时候懒惰到境界的时候,要是左手已经搁在键盘上,就懒得抬起我的右手,去移动点击鼠 标,多麻烦累人啊。 直接左手指头垂直
11、动个几厘米多轻松多方便啊;像我大学同学,电脑不 知出了什么问题,鼠标都是使用不灵, 所以他的大部分上网操作都是键盘完成的;还有些用户有手部残疾或缺陷而无法控制鼠标做出微笑的移动,按键为他们提供了一个很好的备选方案,除非JavaScript 开发人员忘记照顾他们。而实际上,包括我在内的许多前端开发 工程师,或是省功夫,或是其他什么原因,而将这部分人群当作成年的包裹,都扔掉了。屏幕阅读器有些人不能使用常规的浏览器。最典型的就是盲人和视力受损的人,他们无法看到屏幕上的任何东西。作为替代品,他们需要一个能把页面内容大声朗读出来的程序。这就是屏幕阅读器。以前我纯粹按照自己臆想的经验,认为,盲人用户用电脑
12、,估计就是个梦,就算有屏幕阅读器这类东西,估计也做不了什么操作。但是,路要自己走才知道多远, 水要自己趟才知道多深。对自己没有经历过事情的认知往往总是不准确的,对于盲人用户与上网的认识也是如此。我发现自己认知的偏差是因为腾讯CDC的闭上眼睛用QQ -盲人用户探访实录”这篇文章。企鹅公司就是企鹅公司,有钱有人有访谈,这次访谈实录对于像我这样没有时机亲历盲人用户的开发人员来讲是非常珍贵的一手资料,让我意识到,盲人用户也有些他们精彩的世界,他跟我们这些视力良好的人一样,也是可以很好的体验到web给我们生活带来的快乐的。作者注:下面这段摘自闭上眼睛用QQ -盲人用户探访实录”一文。盲人用户所有的电脑操
13、作都依赖于读屏软件和键盘来完成。这三位用户现在使用的都是永德读屏软件,它安装后即在后台运行,把普通的操作系统变成了带语音的操作系统。盲人朋友依靠tab键,方向键和部分快捷键来调整目前光标的所在位置,而每按一次键盘,或 屏幕上出现新的内容, 或可操作界面上状态出现任何变化,系统都会有语音提示, 这样盲人朋友也可以像普通人一样对电脑进行操作了。由于多年的训练,盲人所用的语音库的语速都非常快,普通人难以识别。顺带说一句,目前国内的读屏软件都不廉价,如永德是在1200左右,而一个盲人按摩师的月收入也就1、2千吧,问及他们是否会觉得这个软件太贵,老板娘笑了笑说:我觉得值! ”电脑和网络给盲人带来了全新的生活。图片来自腾讯 CDC小黄和他的电脑右边的数字键盘对他们很重要信息无障碍是我们应尽的公益责任,而我国是
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 二零二五版护工医疗设备操作合同3篇
- 二零二五版教育培训机构短期教师派遣合同
- 二零二五版环保型房产与土地使用权买卖合同9篇
- 2025年度环保型铲车租赁及维护保养服务合同4篇
- 二零二五版智能门禁系统用户体验优化合同4篇
- 2025年度服装代购代理服务合同范本7篇
- 2025年度科技产品广告创意制作合同4篇
- 二零二五年度鱼塘租赁合同(含渔业基础设施共建及共享)4篇
- 2024租赁合同详细条款
- 2025年度厂房租赁与使用权转让合同3篇
- 劳务协议范本模板
- 2025大巴车租车合同范文
- 人教版(2024)数学七年级上册期末测试卷(含答案)
- 2024年国家保密培训
- 2024年公务员职务任命书3篇
- CFM56-3发动机构造课件
- 会议读书交流分享汇报课件-《杀死一只知更鸟》
- 2025届抚州市高一上数学期末综合测试试题含解析
- 公司印章管理登记使用台账表
- 砖厂承包合同签订转让合同
- 2023年公务员多省联考《申论》题(广西B卷)
评论
0/150
提交评论