Я хочу динамически изменять фон в 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 =
"...";
Есть ли способ это сделать?
javascript
base64
background-image
Игорь Савинкин
источник
источник
url('
должно работать, моя проблема заключалась в том, что в URL-адресе данных ActionScript действительно были символы новой строки, и мне пришлосьreplace(/\n/g, '')
Ответы:
Я пытался сделать то же самое, что и вы, но, видимо, 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/
источник
#ancestor.backgroundA .Change{background-image:...}
и#ancestor.backgroundB .Change{background-image...}
, где#ancestor
идентификатор общего предка, а.Change
класс, применяемый ко всем элементам, к которым применяется один из фонов.Была такая же проблема с 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 + "')");
источник
data:image/png;base64
длинно, а строка определяется как переменная jquery, то не работает. Но работает, если строка определена как переменная php, например, в примере PHClaus .... Просто информация о том, что я тестировалДобавление этого трюка к следующему решению Габриэля Гарсиа -
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);
источник
Что я обычно делаю, так это сначала сохраняю полную строку в переменной, например:
<?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; ?>">
Работает на меня ;)
источник
Это правильный способ сделать чистый звонок. Нет 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, "") + "')");
источник
В моем случае это было просто потому, что я не установил
height
иwidth
.Но есть еще одна проблема.
Фоновое изображение можно удалить с помощью
element.style.backgroundImage=""
но не может быть установлен с помощью
element.style.backgroundImage="some base64 data"
Jquery отлично работает.
источник