2

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

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

这里发生了什么,为什么要这样做?图像是否在 base64 的某个时间点以某种方式保存到本地存储?

为了澄清,我在问这个src="image:/部分。

4

2 回答 2

5

您看到的不是HTML5 数据属性,而是数据 URI 方案。引用维基百科:

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

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

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

于 2013-01-04T23:29:24.857 回答
0

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

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

data-src 属性是 javascript 使用 holder.js 脚本生成要进入 src 的数据的指令。

因此 holder.js 生成图像,然后将其作为数据 uri 加载到 img 中,如其他答案所述。

于 2013-12-21T15:30:58.403 回答