多个base64文件合二为一

时间:2014-02-05 05:25:01

标签: html image base64

您可以将这两张图片合并到this JS fiddle上的一个外部文件中,并将其作为图片链接到这些文件吗?

这样的东西
<img src="base64.html#img1" />
<img src="base64.html#img2" />

我确实看到了这个答案,但它没有提供任何例子 Can multiple base64 documents be stored in a single file?


如何在文件名中使用点,并以某种方式使文件认为它是一个不同的文件名,如base64.img1.html,并以某种方式使用文件头将它们拆分为一个文件但不同的部分。


好的,新主意..如果有办法指定charStartcharEnd怎么办?想象一下,有2个base64编码文件,然后你调用一个像

base64.0-3214.html // for one file (like font.woff)
base64.3215-5673.html // for another file (like demo.jpg)

7 个答案:

答案 0 :(得分:3)

可以将所有资源(JavaScript,CSS,字体,图像)放在一个大的(可缓存的)JavaScript文件中。该文件看起来很混乱(因为一些冗长的CSS和Base64字符串),但不要让它让你失望;您可以使用代码生成从其单独的组件中编译JavaScript文件(参见下文)。

演示: http://jsfiddle.net/PgdXd/

CSS

将整个样式表放在单个字符串文字中(不要忘记转义引号和换行符)并将其嵌入到动态创建style元素的JavaScript语句中。

$('head').append("<style> ......... </style>");

注意:我在这里使用jQuery,但是普通的JavaScript也可以。

上述声明可能对较旧的网络浏览器版本无效。有关替代方案,请参阅:How to dynamically create CSS class in JavaScript and apply?

字体

将Base64编码的字体文件嵌入样式表中,如下所述:http://sosweetcreative.com/2613/font-face-and-base64-data-uri

@font-face {
    font-family: 'latoregular';
    src: url(data:application/x-font-woff;charset=utf-8;base64,........) format('woff');
    font-weight: normal;
    font-style: normal;
}

如前所示,这应该嵌入到包含样式表的JavaScript语句中:

$('head').append("<style> @font-face { font-family:'latoregular'; src: url(data:application/x-font-woff;charset=utf-8;base64,........) format('woff'); font-weight:normal; font-style:normal; } .... </style>");

图片

有两种口味。可以在样式表中指定背景图像,就像我们使用字体一样:

.logo1 { background-image: url(data:image/png;base64,.......); }

第二种味道是常规图像。在HTML文件中,使用img标记,其中包含空src属性。

<img alt="" src="" class="icon1" />

使用javascript填充src属性。整个Base64字符串是嵌入在JavaScript语句中的字符串文字。

$('.icon1').attr('src', 'data:image/png;base64,.......');
$('.icon2').attr('src', 'data:image/png;base64,.......');

CSS类确定哪些数据属于哪个img标记。某个类在一个或多个将包含此JavaScript文件的HTML页面中未使用是可以的。 Base64字符串只是传递了一下;其他基于JavaScript的方法也涉及到相同的可忽略的开销。

代码生成

这是一个使用bash脚本的简单示例。但请随意使用Perl或T4或您喜欢的任何语言或工具。

gendatauri.sh:输出数据URI;参数是文件名和(可选)MIME类型。

#!/bin/bash
echo "data:${2:-$(file -bi $1)};base64,$(base64 -w0 $1)"

genimgsrc.sh:生成jQuery语句以填充src元素的<img>属性;参数是文件名。

#!/bin/bash
filename=$1
basename=${filename##*/}
classname=${basename%.*}
echo "\$('.$classname').attr('src','$(./gendatauri.sh $filename)');"

gencss.sh:你的样式表;使用$(./gendatauri.sh FILENAME [MIMETYPE])注入文件数据。例如:

#!/bin/bash
cat << EOF
@font-face {
    font-family: 'latoregular';
    src: url($(./gendatauri.sh latoregular.woff "application/x-font-woff;charset=utf-8")) format('woff');
    font-weight: normal;
    font-style: normal;
}
.logo1 {
    background-image: url($(./gendatauri.sh icon1.png));
}
EOF

genjs.sh:将所有不同的组件合并为一个JavaScript文件。例如:

#!/bin/bash

# CSS, including fonts and background images
(
    echo '$("head").append("<style>\n'
    ./gencss.sh
    echo '\n</style>");'
) | tr '\n' ' '
echo

# images
./genimgsrc.sh icon1.png
./genimgsrc.sh icon2.png

# JavaScript
cat YourOwnFunctions.js

运行它并重定向其输出以生成最终的JavaScript文件。当你这样做时,请确保存在.png.woff和其他资源文件。

./genjs.sh > GeneratedJavaScriptFile.js

在每个HTML文件中包含JavaScript文件:

<script src="GeneratedJavaScriptFile.js"></script>

为了清楚起见:在网络服务器上,您只需要GeneratedJavaScriptFile.js.html个文件;原始资源文件不需要出现在那里。

答案 1 :(得分:2)

Data-uris,这里的关键,是字符串,而不是编码为base-64。

因为它们是字符串,所以可以将它们连接为任何其他字符串。但是,您不能将连接的(data-uri)字符串直接设置为图像源。

连接时,您需要使用分隔符,以便在将它们设置为图像源之前在到达时将它们分开。

您可以将以下字符串作为base-64编码数据-uris:

var img1 = 'data:...',
    img2 = 'data:...';

连接版本看起来像这样,例如$作为分隔符char:

var conc = img1 + '$' + img2;

此字符串现在可以通过包含两个数据uris的网络发送。

在抵达服务器时再次拆分:

var conc = getDataString();   /// some function to get the string from server
var images = conc.split('$'); /// split the string on the $ char
var img1 = images[0];         /// first index contains first string etc.
var img2 = images[1];

/// set the image sources
document.getElementById('image1').src = img1;
document.getElementById('image2').src = img2;

这当然需要错误检查和验证等等,但对于这个原则,这是实现此目的的一种方式。

请注意,只需将它们作为链接引用即可自动拆分它们。服务器当然可以解析链接并提供所需的单个数据 - 正如典型的那样。但是,如果你理解你的问题,如果你想从服务器获得代表两个(或更多)图像的单个字符串,那么你需要在客户端手动拆分它们。

注2:base-64编码图像比原始二进制图像大33%+浏览器能够将其用作源所需的data-uri头。问题可能是,如果以这种方式做任何增益,或者由于base64开销,服务器检索二进制数据的额外请求的总成本总计会更少。只差我2美分..

希望这有帮助(而且我没有完全误解你的问题)。

答案 2 :(得分:1)

在数据URI规范中的纯HTML中是不可能的。 (http://en.wikipedia.org/wiki/Data_URI_scheme

可以使用JavaScript只抓取base64数据/文档的子字符串,并将其设置为img的src属性,如链接的答案所示。

我只是不确定以这种方式做到这一点是值得的,看起来相当复杂,加载时间可能会非常小。


如果你想使用它,一种方法可以做到这一点(简单的草稿,没有错误处理,没有花哨的功能): 在HTML文档中:

<script type="text/javascript" src="base64file.js" />
....
<img id="image0" src="" />
....
<img id="image1" src="" />
....
<script type="text/javascript">
   var singleImages = allImages.split('$');
   document.getElementById('image0').src = 'data:image/png;base64,' + singleImages[0];
   document.getElementById('image1').src = 'data:image/png;base64,' + singleImages[1];
   ....
</script>
你的base64file.js中的

allImages = 'abc... <- the base64 code for the first image
             $ <- split indicator that is not a part of the base64 character set
            cba.... <- the base64 code for the second image
            ';

答案 3 :(得分:1)

将每个base64编码的图片放在自己的文件中,然后使用服务器端代码在HTML页面中插入base-64数据。服务器将看到三个单独的文件,但客户端(即Web浏览器)被提供一个大文件。现在,您只有HTML页面的一个大HTTP请求以及两个图片。如有必要,使用mod_rewrite使Web浏览器相信它是一个静态可缓存的HTML页面,而不是服务器端的PHP / Perl /无论页面。

简单的PHP示例(在Ubuntu 12.04上测试):

<img src="data:image/png;base64,<?php readfile("image1.base64.txt"); ?>" />
<img src="data:image/png;base64,<?php readfile("image2.base64.txt"); ?>" />

注意:确保base64文件末尾没有换行符。

答案 4 :(得分:1)

使用图像数组。这不需要javascript,只需要HTML和CSS。

首先,使用图形编辑器(例如GIMP)将图片拼接成一张大图。

image array

然后使用CSS属性(widthheightbackground-position)动态裁剪图像。 <img>不支持此功能,但背景图片支持此功能。

.iconarray
{
    display: block;
    background-image: url(iconarray.png);
    background-repeat: no-repeat;
}

.icon1
{
    width: 64px;
    height: 64px;
    background-position: 0px 0px;
}

.icon2
{
    width: 64px;
    height: 64px;
    background-position: 0px -64px;
}

使用<span>中的CSS类:

<span class="iconarray icon1"></span>
<span class="iconarray icon2"></span>

演示: http://jsfiddle.net/rFTpL/

Kudos转到:

答案 5 :(得分:1)

我的答案很简单。

var data64imgs = ['', ''];

$(function () {
    $('[data-index]').each(function () {
        $(this).attr("src",data64imgs[parseInt($(this).data("index"))]);
    });
});

将上述代码粘贴到单独的JS文件中,并在需要的地方引用它。

这样做:

<img data-index="0" />
<img data-index="1" />

现在自动显示图像。

这是Demo

注意如果你想要额外的img,然后将它添加到数组中就可以了,只需使用适当的索引。

答案 6 :(得分:1)

据我所知,您希望使用单个HTTP请求缓存各种类型的资源(如字体,图像等)。

所以,这是我对jQuery的看法(你可以选择使用vanilla JavaScript):

首先,您可以将所有数据缓存存储为JavaScript中的关联数组中的字符串或布尔值或数字,并加载此单个文件,如下所示。

var ResourceLibrary = [];
ResourceLibrary["hello"] = "Hello World!";
ResourceLibrary["genderMale"] = true;
ResourceLibrary["username"] = "srvikram13";
ResourceLibrary["isDeveloper"] = true;
ResourceLibrary["firefox"] = "...."
ResourceLibrary["chrome"] = "...."

现在,对于您希望应用缓存数据的每个元素,您可以提供自定义属性 - data-src,如下所示。

<img src='#' data-src='resourceId-firefox' alt='firefox' />
<img src='#' data-src='resourceId-chrome' alt='chrome' />
<p data-src='resourceId-hello'></p><br>
<input id='username' data-src='resourceId-username'/><br>
<input type="radio" data-src="resourceId-genderMale" />Male<br>
<input type="checkbox" data-src="resourceId-isDeveloper" />Developer<br>

现在在document.ready(或onload,如果使用vanilla JS),只需使用此自定义属性循环遍历每个元素;并根据相应的resourceId应用缓存值。

$(document).ready(function(){
    $("*").each(function(i, e){
        if($(e).attr("data-src") && $(e).attr("data-src").indexOf("resourceId-") != -1) {
            switch($(e).get(0).tagName) { // Add more case statements to handle various types of elements
                case "INPUT" : 
                    if(!$(e).attr("type")){
                        $(e).val(ResourceLibrary[$(e).attr("data-src").replace("resourceId-", "")]);
                        return;
                    }
                    switch($(e).attr("type").toLowerCase()) {
                        case "radio":
                        case "checkbox":
                            $(e).attr("checked", ResourceLibrary[$(e).attr("data-src").replace("resourceId-", "")])
                    }
                    return;
                case "IMG" :
                    $(e).attr("src", ResourceLibrary[$(e).attr("data-src").replace("resourceId-", "")]);
                    return;
                case "P" :
                    $(e).html(ResourceLibrary[$(e).attr("data-src").replace("resourceId-", "")]);
                   return;
                default:
                   return;
            }
        }
    });
});

Working Demo