空白图像编码为data-uri

Jen*_*and 67 html5 web-standards data-uri

我已经构建了一个图像滑块(基于极好的bxSlider),它会在滑入视图之前及时预加载图像.它已经很好用,但我不认为我的解决方案是有效的HTML.

我的技术如下:我生成滑块标记,第一张幻灯片图像像往常一样插入(带有<img src="foo.jpg">),后续图像在数据属性中被引用<img data-orig="bar.jpg">.然后Javascript data-orig -> src在必要时调整更改,触发预加载.

换句话说,我有:

<div class="slider">
    <div><img src="time.jpg" /></div> 
    <div><img src="data:" data-orig="fastelavn.jpg" /></div> 
    <div><img src="data:" data-orig="pels_strik.jpg" /></div> 
    <div><img src="data:" data-orig="fashion.jpg" /></div> 
</div>
Run Code Online (Sandbox Code Playgroud)

为了避免空src=""属性(在某些浏览器对性能有害),我插入了有效插入空白图像作为占位符.src="data:"

问题是,我似乎无法在文档中找到data-URI来说明这是否是一个有效的数据URI.我基本上想要解析为空白/透明图像的最小数据URI,因此浏览器可以立即解析src并继续(没有错误或网络请求).也许src="data:image/gif;base64,"会更好?

Jen*_*and 151

我调查了它,编码为数据uri 的最小可能的透明GIF图像是这样的:



这就是我现在正在使用的.

  • 如果您的“img”元素已隐藏,并且您只是想避免 HTTP 404 错误,请参阅 http://stackoverflow.com/a/14115340/14731 以获取非透明图像的较短数据。 (2认同)

fca*_*ran 27

如果您需要透明图像1x1像素,只需将此数据uri设置为src默认属性


Run Code Online (Sandbox Code Playgroud)

相反,这是图像1x1白色的base64编码


Run Code Online (Sandbox Code Playgroud)

否则你可以data:null为每个图像设置并保存约60个额外字节

  • 你能提供一个链接来验证数据:null是否有效作为图像源? (4认同)
  • data:null无效. (3认同)

aze*_*ati 23

我见过的最小的

数据:图像/ GIF; BASE64,R0lGODlhAQABAAAAACw =

  • 当然,除了一个只是Chrome.在Firefox中打开它你会得到`图像无法显示,因为它包含错误`.见http://proger.i-forge.net/%D0%9A%D0%BE%D0%BC%D0%BF%D1%8C%D1%8E%D1%82%D0%B5%D1%80/ [20121112]%第二十条%20smallest%20transparent%20pixel.html (6认同)

Adr*_*ria 19

data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg"/>
Run Code Online (Sandbox Code Playgroud)

有效且高度可压缩.如果页面中有另一个内联svg,则基本上是免费的.

  • 我喜欢这一个.我只看到两个弱点:首先,IE <9不支持SVG(通常不是问题,但它确实使某些网站不可行); 第二,"SVG数据需要在IE和Firefox中工作"(参见http://caniuse.com/#search=datauri),所以你实际上必须使用:`
Run Code Online (Sandbox Code Playgroud)

更小:D

  • http://proger.i-forge.net/The_smallest_transparent_pixel/eBQ (2认同)
  • 该链接指出,此字节和14字节字节的字节均仅适用于Chrome浏览器,并且不能保证它能在所有浏览器上正常工作。此外,生成的gif似乎没有在任何图像编辑器中打开。所以我会犹豫使用它。 (2认同)

Mat*_*kas 7

1px xpp JPEG图像


Run Code Online (Sandbox Code Playgroud)


Maë*_*son 5

Fabrizio 的“白色 gif”实际上并不完全是白色的:它是rgb(254, 255, 255).

我使用以下一个(碰巧较小),在此页面上找到。


Run Code Online (Sandbox Code Playgroud)