有没有办法将background-image设置为base64编码的图像?

Is there a way to set background-image as a base64 encoded image?

本文关键字:编码 base64 图像 设置 background-image 有没有      更新时间:2023-09-26

我想在JS中动态改变背景,我的图像集是base64编码的。我试着:

document.getElementById("bg_image").style.backgroundImage = 
   "url('http://amigo.com/300107-2853.jpg')"; 

与完美的结果,

,但我没有这样做:

document.getElementById("bg_image").style.backgroundImage = 
   "url('...')";

document.getElementById("bg_image").style.backgroundImage = 
   "...";

有办法吗?

我试图做同样的你,但显然backgroundImage不与编码的数据工作。作为替代方案,我建议使用CSS类和这些类之间的变化。

如果您正在生成数据"在飞行"你可以动态加载CSS文件。

function change() {
  if (document.getElementById("test").className == "backgroundA") {
    document.getElementById("test").className = "backgroundB";
    document.getElementById("test2").className = "backgroundA";
  } else {
    document.getElementById("test").className = "backgroundA";
    document.getElementById("test2").className = "backgroundB";
  }
}
btn.onclick = change;
.backgroundA {
  background-image: url("");
}
.backgroundB {
  background-image: url("");
}
<div id="test" height="20px" class="backgroundA">
  div test 1
</div>
<div id="test2" name="test2" height="20px" class="backgroundB">
  div test2
</div>
<input type="button" id="btn" />

我在这里摆弄了一下,按下按钮,它会切换div的背景:http://jsfiddle.net/egorbatik/fFQC6/

对于base64也有同样的问题。给将来遇到同样问题的人:

url = "...";

这将在控制台执行,但不能在脚本中执行:

$img.css("background-image", "url('" + url + "')");

但是在玩了一会儿之后,我想到了这个:

var img = new Image();
img.src = url;
$img.css("background-image", "url('" + img.src + "')");

不知道为什么它与代理图像一起工作,但确实如此。在Firefox Dev 37和Chrome 40上测试。

希望能帮到别人。

编辑

进一步调查了一下。似乎有时base64编码(至少在我的情况下)与CSS中断,因为在编码值中存在换行符(在我的情况下,值是由ActionScript动态生成的)。

简单地使用例如:

$img.css("background-image", "url('" + url.replace(/('r'n|'n|'r)/gm, "") + "')");

也可以,甚至似乎比使用代理图像快几毫秒。

试试这个,我得到了成功的回应。它运行

$("#divId").css("background-image", "url('data:image/png;base64," + base64String + "')");

将此技巧添加到gabriel garcia的以下解决方案中-

var img = 'data:image/png;base64, ...'; //place ur base64 encoded img here
document.body.style.backgroundImage = 'url(' + img + ')';

然而,在我的情况下,这不起作用。将url移到img变量中就可以了。所以最后的代码看起来像这样

var img = "url('data:image/png;base64, "+base64Data + "')";
document.body.style.backgroundImage = img; 

我尝试了这个(并为我工作):

var img = 'data:image/png;base64, ...'; //place ur base64 encoded img here
document.body.style.backgroundImage = 'url(''' + img + ''')';

ES6语法:

let img = 'data:image/png;base64, ...'
document.body.style.backgroundImage = `url('${img}')`

稍微好一点:

let setBackground = src => {
    this.style.backgroundImage = `url('${src}')`
};
let node = nodeIGotFromDOM, img = imageBase64EncodedFromMyGF;
setBackground.call(node, img);

这是进行纯调用的正确方法。没有CSS。

<div style='background:url()repeat-x center;'></div>

我想这会有帮助,Base64由CSS以不同的方式处理,您应该将图像的数据类型设置为Base64,这将有助于CSS将Base64更改为图像并将其显示给用户。你可以在javascript中使用jquery脚本指定背景图像,它会自动将base64改为mage并显示它

url = "data:image;base64,"+data.replace(/('r'n|'n|'r)/gm, "");
$("body").css("background-image", "url('" + url.replace(/('r'n|'n|'r)/gm, "") + "')");

当使用数据uri时,url中使用引号

li {
  background:
    url()
    no-repeat
    left center;
  padding: 5px 0 5px 25px;
}

我通常做的是首先将完整字符串存储到一个变量中,如下所示:

<?php
$img_id = '...';
?>

然后,我想让JS对这个变量做点什么:

<script type="text/javascript">
document.getElementById("img_id").backgroundImage="url('<?php echo $img_id; ?>')";
</script>

你可以通过PHP直接引用相同的变量,比如:

<img src="<?php echo $img_id; ?>">

在我的例子中,这只是因为我没有设置heightwidth

但是还有一个问题。

可以使用

删除背景图像

element.style.backgroundImage=""

但不能使用

设置

element.style.backgroundImage="some base64 data"