- objective-c - iOS 5 : Can you override UIAppearance customisations in specific classes?
- iphone - 如何将 CGFontRef 转换为 UIFont?
- ios - 以编程方式关闭标记的信息窗口 google maps iOS
- ios - Xcode 5 - 尝试验证存档时出现 "No application records were found"
灵感来自 this question ,张贴者随意声明<object>
应该使用而不是 <img>
在 HTML 文档中嵌入图像。
I'm developing a web app at the moment, and, being a perfectionist, I try to make it all shiny and compliant with all the standards. As far as I know, the
<img>
tag is to be deprecated in the upcoming standards for xHTML, and as nowadays even IE is able to handle<object>
properly, I wanted to use the<object>
tag for all the images on my site
很明显,张贴者所说的“即将到来的标准”是被遗弃的 XHTML2规范,甚至没有正式弃用 <img>
反正。 (尽管显然有 rumors 达到这种效果。)
据我所知,我在 Web 开发社区中没有看到任何人提倡使用通用 <object>
标记可以说更具语义且绝对更兼容 <img>
标签。
使用 <object>
有充分的理由吗?而不是 <img>
?应该<object>
甚至可以用来代替 <img>
– 这会破坏什么?
最佳答案
回答标题中的问题:是的,它当然有效。 object
元素的有效性甚至不依赖于嵌入的数据类型。如果您想问它是否正确,那么答案是肯定的,规范中没有禁止或建议反对的内容。
在使用 object
嵌入图像的可能原因中,最实际的是它允许后备内容包含 HTML 标记,例如标题、列表、表格和短语标记。 img
元素允许您仅指定纯文本作为后备内容——甚至不能指定分段符。
出于可访问性原因,任何图像都应具有要呈现的后备内容,例如在非视觉浏览(屏幕阅读器、盲文等)中使用文档或出于某种原因未显示图像时。对于任何内容丰富的图像(例如,组织结构图或描述复杂流程的绘图),回退内容需要很长并且需要具有某种结构。
但是,很少使用object
来嵌入图像。后备内容的重要性并未得到广泛理解,实际的经济和技术考虑常常导致后备问题被忽视。此外,object
长期以来在浏览器中的实现速度缓慢、漏洞百出且质量不佳。直到最近,相当安全地使用 object
来包含图像才变得可行。
哪个元素更具语义的问题大多是徒劳的,答案通常反射(reflect)了对“语义”概念的各种误解。 img
和object
都表示包含(嵌入)外部内容。 img
元素原则上用于包含图像,无论是什么意思,尽管它也被用于包含视频。对于 object
元素,type
属性可用于指定嵌入内容的类型,具体到特定的图像类型,例如type=image/gif
,或者它可以保持打开状态。
这意味着 object
元素更灵活:您可以不指定类型,让它在 HTTP header 中指定。这样,嵌入数据的类型可以在不改变 object
元素或一般嵌入文档的情况下改变;例如,您可以从一个简单的版本开始,其中嵌入的内容是图像,然后将其替换为 HTML 文档(例如包含图像和文本)。
关于image - 使用 <object> 而不是 <img> 包含图像是否有效?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10407236/
我想替换每一个 带结束标记 字符串中的标记。该字符串实际上是一个 html 文档,其中 img 标记由我生成,并且始终如下所示: Src 是用户输入,所以它可以是任何东西。我做了一个正则表达式,不确
我使用数组通过 getElementsByClassName 存储我所有的 imgs。 我需要知道哪个 img 被点击或 mouseover/mouseout,所以我使用循环来检查哪个 img 被点击
我正在尝试使用图像制作一款类似 Match3 的游戏,但我无法进行比较。我正在为固定数量的 atm 执行此操作,只是为了让它正常工作,稍后应该在 foreach 循环中。如果有什么区别的话,该函数位于
我希望你能帮助我:) 我想定义 img 的高度,相对于图像的“实际”宽度。但宽度是动态的,因为它占父对象的百分比(wxample 的浏览器窗口)。 为什么我需要高度?:没有高度它工作正常,但我需要它,
我知道这个话题被讨论了很多,但我找不到任何适合我的解决方案。所以,我的代码大致是: var img =me.images[curID] var f = function() { var
我试图在一个页面上列出多个图像,但当您单击图像时,它会以模式打开。 它适用于第一张图片,但不适用于其他图片,我假设这是一个 JS 问题,我尝试设置一个空的 var,然后将其设置为获取元素 ID(每个
任务:我们正在通过 HttpWebRequest 抓取 HTML 内容(约 6,000 个调用)。该字符串经过修剪并存储在 SQL Server 2014 数据库中,以便作为 XML 进行处理。 问题
我从上面得到这个错误,不知道如何避免它。我的目的是获取屏幕截图,然后对其进行模板匹配,以查看此时屏幕上是否显示图标。到目前为止,它只是图标的位置。我的代码: #include "opencv2/hig
我有一个包含图像的容器,该图像是从应用程序加载的,因此容器的尺寸是已知的,而图像会有所不同。 我目前有以下 css: #secondary_photos { height: 100px; wi
我正在尝试设置一个随分辨率缩放但看起来仍然不错的页面背景..这就是我正在使用的.. 站点是http://www.gd-gaming.com/wordpress ,如果你用 Firebug 检查它,它只
目前我有 如何删除包装 img 标签的 p 标签? 所以我可以得到.. 最佳答案 使用 $('p > img').unwrap(''); 这将删除 img 周围的所有 p。您应该使用 cl
我想要动画 3 .svg图片: 和css : .sequence { position: relative; } .sequence img { position: ab
我有外部 RSS 提要填充以下重复出现的类 elements 。 {teaserImage} {teaserImage} {teaserImage} 我想简单地获取 :first 实例,该实例也是来自
这是一个独特的问题: 我不想使用浏览器 JavaScript 来解决这个问题,请继续阅读... 我要转换 通过编译应用程序( ng build 或 ng serve )到 Base64 img 标签,
悬停在 中的第一张图片上标记,我需要使用 CSS 增加第二张图片的不透明度。我试过使用 +和 ~运营商,无法让它发挥作用。任何帮助将不胜感激。 最佳答案 a:hover + img
我已经尝试解决这个问题有一段时间了,但我迷路了,有人吗? for(var i=0; i<10; i++) { var Img = new Image(); Img.onload = (
这就是我想要实现的目标: 当用户将鼠标悬停在较小的图像之一上时: 较小的图像 + 文本应替换较大的图像 + 文本。 当用户没有悬停时;将大集返回到其原始图像和文字。 这就是我到目前为止所拥有的。它没有
我知道如何在 php 中执行此操作,但我需要在 javascript/jquery 中完成此操作。 我正在尝试执行以下操作: $('#NewBox').html( $('#OldBox').html(
我正在使用一个 CMS (ExpressionEngine),它将段落标签包裹在图像周围。我正在使用响应式图像(最大宽度:100%),并且由于我还在段落上定义宽度,因此它会导致问题。我想使用 jQue
Tinymce 正在删除我的 img 结束标记并生成无效的 xhtml。 它变成了这个 进入这个 我也在使用 codemagic,但是在查看 html 时它仍然显示 .我也试过包括 , 但输出是
我是一名优秀的程序员,十分优秀!