今天忽然才明白html中title和alt属性的区别,哎,这么多年了,竟然一直在用alt

原文地址

原文内容:

alt属性和title属性
作者:JunChen 2005-5-23 12:00:35
  • 原文:http://www.456bereastreet.com/archive/200412/the_alt_and_title_attributes/
  • 翻译:JunChen
  • 首发:http://blog.handsbrain.com/junchen/archive/2005/05/21/3355.aspx
  • 版权:本文版权归译者Junchen所有,转载请先联系译者。

当浏览器卖主扭曲了标准并且自顾自的不按规则去做一些事,他们可能会造成一些问题,或者至少产生了混淆。例子之一就是一些浏览器处理alt属性(一般会被错误的称作alt标签)的方式,比如拥有大量用户的Windows的IE浏览器。

替换文字(alt text)并不是用来做提示(tool tip),或者更加确切的说,它并不是为图片提供额外说明信息的。相反地,title属性才应该用来为元素提供额外说明信息。这些信息在大部分图像浏览器里显示为提示(tool tip),虽然制造商可以任意采取其他方式渲染title属性的文字。

很多人看来对这两个属性感到迷惑(最近这个问题在Web Standards Group邮件列表里变多了), 所以我写下我的想法,如何去用它们。

alt属性

为不能显示图像、窗体或applets的用户代理(UA),alt属性用来指定替换文字。替换文字的语言由lang属性指定。
来源:How to specify alternate text.

Alt属性(注意是“属性”而不是“标签”)包括替换说明,对于图像和图像热点是必须的。它只能用在img、area和input元素中(包括applet元素)。对于input元素,alt属性意在用来替换提交按钮的图片。比如:<input type="image" src="data:image.gif" alt="Submit" />.

使用alt属性是为了给那些不能看到你文档中图像的浏览者提供文字说明。这包括那些使用本来就不支持图像显示或者图像显示被关闭的浏览器的用户,视觉障碍的用户和使用屏幕阅读器的用户。替换文字是用来替代图像而不是提供额外说明文字的。

在写替换文字前仔细想想,保证那些文字确实为那些看不到图像的人提供了说明信息,并且在上下文中有意义。对于那些装饰性的图片可以使用空的值(alt="",引号中间没有空格),而不是使用不相关的替换文字比如“blue bullet”或者“spacer.gif”。不要忽略它,如果你忽略了,那么一些屏幕阅读器会直接阅读图像文件的文件名,那些文字浏览器,比如Lynx会显示图像文件的文件名,而那对于你的浏览者就没什么用了。

包含文字的图像图片设置替换文字是最简单的,图像中包含的文字一般来说就可以作为alt属性值。

至于替换文字的长度,看看WCAG 2.0(网站内容可用性指南2.0)是怎么说的:

Alt属性值得长度必须少于100个英文字符或者用户必须保证替换文字尽可能的短。

我把它理解为“尽可能短,尽需要长”。

即使你想让它显示为提示(tool tip),也不要给文字元素使用alt属性,这并不是它的用法。至今据我所知,那样做仅能在Windows的IE浏览器和古老的Netscape 4.*(windows版本)有效。没有一个Mac的浏览器会将它显示为提示(tool tip)。

当浏览器把替换文字显示为提示(tool tip)后,那些错误使用alt属性的行为也受到了鼓励。一些人开始写无意思的替换文字,因为他们趋向于认为它是一个额外的说明信息,而不是不能显示图像的替换。其他人可能不想让提示(tool tip)出现,然后就完全忽略了写alt属性值。这些错误的做法,都给那些不能看到图像的浏览者造成了困难。

额外的说明信息和非本质的信息请使用title属性。

title属性

title属性为设置该属性的元素提供建议性的信息。
来源: The title attribute.

title属性可以用在除了base,basefont,head,html,meta,param,script和title之外的所有标签。但是并不是必须的。可能这正是为什么很多人不明白何时使用它。

使用title属性提供非本质的额外信息。大部分的可视化浏览器在鼠标悬浮在特定元素上时显示title文字为提示信息(tool tip),然而这又由制造商来决定如何渲染title文字。一些浏览器会将title文字显示在状态栏里。比如早期版本的Safari浏览器。

title属性有一个很好的用途,即为链接添加描述性文字,特别是当连接本身并不是十分清楚的表达了链接的目的。这样就使得访问者知道那些链接将会带他们到什么地方,他们就不会加载一个可能完全不感兴趣的页面。另外一个潜在的应用就是为图像提供额外的说明信息,比如日期或者其他非本质的信息。

title属性值可以比alt属性值设置的更长。不过要注意的是,有些浏览器会截断过长的文字(比如工具提示或其他)。比如Mozilla核心的浏览器只能显示最先的60个字符。这被认为是一个Mozilla bug,这是你要注意的。

使用前先考虑

我的建议是保证替换文字(alt text)精要。在大多数的应用里,都应该被留白,alt=""(注意两引号中没有空格)。 想想那些图像,为那些浏览者提供了什么样的信息,你应该用什么文字去描述它,或者你该为看不到图像的人提供什么信息? 将替换文字写成“照片:站在大楼外的CEO,穿着灰色西装和黑色领带,望着天”对于看不到图像的人真的有帮助?如果你觉得是,那么你就写吧。在很多情况下,我觉得让替换文字留白比较好。

对于title属性,比较难于给出严格的使用说明。我大部分用在那些不能自我释意的链接上,比如同一页面上的相同的链接文字,不同的链接页面。有时候也为一些按钮或者表单元素提供更多的说明文字。

更长的描述

当一个图片需要更加长的描述,而超过alt属性的限制,那么还有一些选择。

longdesc属性可以用来提供链接到一个包含图片文字描述的单独页面。这就意味着把浏览者链接到另外的页面,这可能会造成理解上的困难。另外浏览器对于longdesc属性的支持也是不一致的,并且不是非常好。

longdesc属性可以包含一个链接到当前文档的其他部分(锚点)来取代链接到另外的页面。在Accessibility footnotes, Andy Clarke很好的解释说明了如何应用。

描述链接(D links)可以用来补充longdesc。一个描述链接就是一个常规的链接,连接到含有替换文字的页面。该链接被置于图像的旁边,并且在所有浏览器中都是可是的。对于它的有效性人们有很多不同意见,我的个人意见不大喜欢这个注意。WCAG也是,在他们的工作草案HTML Techniques for WCAG 2.0中,描述链接是被“不赞成”的。

如果对图片的长的描述对于任何浏览者都有用,那么你得考虑让它简单的显示在同一个文档里面,而不是链接到其他页面里或者藏起来。这样每个人都可以阅读到。这是一种简单低技术含量的方法。

html中title和alt属性的区别相关推荐

  1. <img> 的 title 和 alt 属性的区别

    1.<img> 的 title 和 alt 属性的区别 alt是img的特有属性,除了装饰性的图片外,必须设置有意义的值,搜索引擎会重点分析 作用是图片无法加载时用来替代的文字说明 tit ...

  2. ueditor html显示图片,百度ueditor编辑器上传图片后img标签的title、alt属性优化简单方法...

    <百度ueditor编辑器上传图片后img标签的title.alt属性优化简单方法>要点: 本文介绍了百度ueditor编辑器上传图片后img标签的title.alt属性优化简单方法,希望 ...

  3. img 标签 的 title 和 alt 有什么区别

    img标签 的 title 和 alt 有什么区别 1. title 是共有属性 ⿏标悬浮到元素上的时候显示相应提示 2. alt 是 <img> 的特有属性,⽤于图⽚⽆法加载时显示.读屏 ...

  4. spring配置中id和name属性的区别

    可能大家在网上都应该搜索过在 Spring 配置中 id 和 name 属性的区别,可能你会搜索到有一大堆的区别,不过在我这里可能不一样了. 我这里 Spring 的版本为 3.2.4,区别不是很大, ...

  5. C#中的字段与属性的区别及属性的作用

    C#中的字段与属性的区别及属性的作用 先上代码 public class Employee {//字段private string name;//属性public string Name {get { ...

  6. <img>标签上title属性与alt属性的区别

    alt属性是为了给那些不能看到你文档中图像的浏览者提供文字说明的.且长度必须少于100个英文字符或者用户必须保证替换文字尽可能的短, 下·不支持图像显示或者图像显示被关闭的浏览器的用户,视觉障碍的用户 ...

  7. 标签上的 title属性与 alt属性的区别

    1.含义不同 alt是当图片不存在时的替代文字;title是对图片的描述与进一步说明 2.在浏览器中的表现不同 在firefox(火狐浏览器)和ie8中,当鼠标经过图片时title值会显示,而alt的 ...

  8. title和alt属性

    为什么80%的码农都做不了架构师?>>>    首先明确一下概念,alt是html标签的属性,而title既是html标签,又是html属性. title标签这个不用多说,网页的标题 ...

  9. 标签上 title 与 alt 属性的区别是什么?

    alt 是给搜索引擎识别,在图像无法显示时的替代文本: title 是关于元素的注释信息,主要是给用户解读. 当鼠标放到文字或是图片上时有 title 文字显示.(因为 IE 不标准)在 IE 浏览器 ...

最新文章

  1. 指针系统学习7-返回指针值的函数
  2. CSS中background-position详述
  3. 三、python+selenium
  4. 项目管理(2):备战pmp
  5. POJ 1159 (DP)
  6. ssm框架mysql自增_手把手教你整合最优雅SSM框架
  7. Win8Metro(C#)数字图像处理--2.18图像平移变换
  8. oracle job 及存储过程案例
  9. Ubuntu21.04 安装 VLC视频播放器
  10. 瑞友天翼 v5.1.0.6 远程打印跳行、跳页、错位问题解决方法
  11. 频谱泄露和吉布斯现象
  12. 千亿级数仓项目(三)
  13. TCP/IP协议各层的网络设备
  14. linux cp 性能,linux性能监控以及优化之CPU
  15. mysql usleep_date、sleep和usleep命令
  16. 网络聊天室(linux,java,Android)
  17. JavaScript实现网页关灯效果
  18. <<多模态预训练—泛读>>2022:BLIP: Bootstrapping Language-Image Pre-training for Unified Vision-Language Unders
  19. 步进电机驱动器控制转速和圈数
  20. Qt开发高级进阶: WebCamera(UVC)摄像头使用QAbstractVideoSurface捕获视频帧到QImage

热门文章

  1. Program Files 目录的dos文件名模式下的缩写PROGRA~1
  2. su和sudo的区别与使用
  3. 快手校招笔试-latex爱好者
  4. leetcode之美团公司算法
  5. python中的pyc文件了解一下?
  6. 算法题:一个圆环上有100个灯泡,灯泡有打开和关闭两种状态,灯泡的状态随机,按一个灯泡的开关,相邻的两个灯泡的状态也发生一次变化。比如暗-亮-暗,按中间灯泡,变化为亮-暗-亮。问设计一道算法,使得所有
  7. 增强式学习:如何使用Q-Learning算法训练围棋机器人
  8. 永久免费VPS推荐:Evolution Host 最高可得4H/4G/80G/1G带宽
  9. 记录hyperic-hq搭建开发环境遇到的坑
  10. 短信验证码的作用是什么?如何选择靠谱的短信验证码平台?