Подтвердить что ты не робот

Есть ли способ установить фоновое изображение в качестве кодированного изображения base64?

Я хочу динамически менять фон в 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 = 
   "...";

Есть ли способ сделать это?

4b9b3361

Ответ 1

Я попытался сделать то же самое, что и вы, по-видимому, 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;

Я попробовал это здесь, нажмите кнопку, и он переключит фон divs: http://jsfiddle.net/egorbatik/fFQC6/

Ответ 2

Попробуйте это, У меня есть успешный ответ..и работаем

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

Ответ 3

Имела ту же проблему с base64. Для любого в будущем с той же проблемой:

url = "...";

Это будет выполняться с консоли, но не из script:

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

работает тоже, и даже кажется, что он быстрее на несколько мс, чем с использованием прокси-образа.

Ответ 4

Добавление этого трюка к следующему решению 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; 

Ответ 5

Я попробовал это (и работал для меня):

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)

Ответ 6

То, что я обычно делаю, заключается в том, чтобы сначала сохранить полную строку в переменной:

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

Работает для меня;)

Ответ 7

Это правильный способ сделать чистый вызов. Нет CSS.

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

Ответ 8

В моем случае это было только потому, что я не установил height и width.

Но есть и другая проблема.

Фоновое изображение может быть удалено с помощью

element.style.backgroundImage=""

но не может быть установлен с помощью

element.style.backgroundImage="some base64 data"

Jquery работает отлично.

Ответ 9

Я думаю это поможет

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