为什么以这种方式使用数据属性?

时间:2013-01-04 23:10:47

标签: html html5 twitter-bootstrap custom-data-attribute

学习如何利用Bootstrap,我注意到缩略图对图像源有奇怪的标记(至少对我来说很奇怪。)

<img data-src="holder.js/260x120" alt="260x120" style="width: 260px; height: 120px;" src="">

这里发生了什么,为什么要这样做?图像是否以某种方式保存到base64中的某个位置?

澄清一下,我问的是src="image:/部分。

2 个答案:

答案 0 :(得分:5)

您所看到的不是HTML5 data- attribute,而是data URI scheme。引用维基百科:

  

数据URI方案...提供了一种在Web中包含数据的方法   页面好像是外部资源。这种技术允许   通常是单独的元素,如图像和样式表   在单个HTTP请求而不是多个HTTP请求中获取,   这可能更有效率。

您所看到的是base64编码的图像数据,在本例中为PNG。当浏览器看到这个时,它们会按照指示对数据进行解码,并将其显示为外部资源。

鉴于这个图像的大小,Bootstrap的创建者正确地认为像这样内联图像而不是将它分开是更有效的。如果他们将它分开,则需要额外的HTTP请求来加载图像,这会增加页面的总加载时间。

答案 1 :(得分:0)

对于Bootstrap,我认为您看到的是用于生成src属性中的数据的Javascript。

如果查看原始源(不是检查器中的源),您可能看不到src属性,只能看到data-src。

data-src属性是javascript的一条指令,它使用holder.js脚本生成要在src中输入的数据。

所以holder.js生成图像,然后将其作为数据uri加载到img中,如其他答案所解释的那样。