您可以将这两张图片合并到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
,并以某种方式使用文件头将它们拆分为一个文件但不同的部分。
好的,新主意..如果有办法指定charStart
和charEnd
怎么办?想象一下,有2个base64编码文件,然后你调用一个像
base64.0-3214.html // for one file (like font.woff)
base64.3215-5673.html // for another file (like demo.jpg)
答案 0 :(得分:3)
可以将所有资源(JavaScript,CSS,字体,图像)放在一个大的(可缓存的)JavaScript文件中。该文件看起来很混乱(因为一些冗长的CSS和Base64字符串),但不要让它让你失望;您可以使用代码生成从其单独的组件中编译JavaScript文件(参见下文)。
演示: http://jsfiddle.net/PgdXd/
将整个样式表放在单个字符串文字中(不要忘记转义引号和换行符)并将其嵌入到动态创建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)将图片拼接成一张大图。
然后使用CSS属性(width
,height
,background-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;
}
}
});
});