有没有办法将背景图像设置为base64编码图像?

时间:2013-06-13 15:07:10

标签: javascript base64 background-image

我想在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 = 
   "...";

有什么办法吗?

8 个答案:

答案 0 :(得分:55)

我试着像你一样做,显然是backgroundImage不适用于借来的数据。作为替代方案,我建议使用css类以及这些类之间的更改。

如果您“动态”生成数据,则可以动态加载css文件。

CSS:

.backgroundA {
    background-image: url(" ");
}

.backgroundB {
background-image:url("");
}

HTML:

<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" />

使用Javascript:

 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;

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

答案 1 :(得分:23)

试试这个, 我得到了成功的回应..正在工作

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

答案 2 :(得分:16)

与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, "") + "')");

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

答案 3 :(得分:6)

将此技巧添加到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; 

答案 4 :(得分:3)

我试过这个(并为我工作):

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)

答案 5 :(得分:2)

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

<?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; ?>">

适合我;)

答案 6 :(得分:0)

在我的情况下,这仅仅是因为我没有设置heightwidth

但是还有另一个问题。

可以使用删除背景图片

element.style.backgroundImage=""

但无法使用设置

element.style.backgroundImage="some base64 data"

jQuery工作正常。

答案 7 :(得分:0)

我认为这会有所帮助

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