base64 图像的 Javascript 数组循环并放置在页面上

标签 javascript arrays src createelement

我正在尝试创建一个 base64 图像的测试循环,以便我可以快速查看 Base64 中的图标在我的 html 页面上的样子。

以下JS代码是我目前正在使用的代码:

var submitBtnIcon    = "...+d6uAAAAAElFTkSuQmCC";
var addBtnIcon       = "...oAAAANSUhEU=";
var clearBtnIcon     = "...MAAADXqc3KAA3NCSVQICAjb4U==";
var exportBtnIcon    = "...+48GgAAAABJRU5ErkJggg==";

var array_Icons = [
    "submitBtnIcon", "addBtnIcon", "clearBtnIcon", "exportBtnIcon"
];

for (i = 0; i < array_Icons.length; i++) {
    var x = document.createElement("IMG");

    x.setAttribute("src", "url('" + array_Icons[i] + "')");
    x.setAttribute("style", "width: 15px; height: 15px; margin-right: 5px;");

    document.body.appendChild(x + '<br/>');
} 

显然这并没有按预期工作。它所做的只是在行 document.body.appendChild(x + '< br/>'); 上抛出一个错误,说:

0x800a139e - JavaScript runtime error: HierarchyRequestError

所以我不确定此时要做什么/去哪里才能解决上面的这个问题并让它实际使用 var xxxxxx 名称代替 array_Icons[I ].

更新 1

enter image description here

使用这段代码:

var array_Icons = [
    submitBtnIcon, addBtnIcon, clearBtnIcon, exportBtnIcon
];

for (i = 0; i < array_Icons.length; i++) {
    var x = document.createElement("IMG");
    var br = document.createElement("br");

    x.setAttribute("src", "url('" + array_Icons[i] + "')");
    x.setAttribute("style", "width: 15px; height: 15px; margin-right: 5px;");

    document.body.appendChild(x);
    document.body.appendChild(br);
}

最佳答案

这是因为

  • 你正在尝试这样做x + '<br/>'即向字符串附加一个 DOM 元素
  • array_Icons 有一个名为变量的字符串数组,即 "submitBtnIcon"而您必须将变量名称放入:[submitBtnIcon] .
  • 你不需要使用url<img>标签,只需设置 src使用 base64 值。

var submitBtnIcon = "";

var addBtnIcon = "";

var clearBtnIcon = "";

var exportBtnIcon = "";

var array_Icons = [
  submitBtnIcon, addBtnIcon, clearBtnIcon, exportBtnIcon
];

for (i = 0; i < array_Icons.length; i++) {
  var x = document.createElement("IMG");
  var br = document.createElement("br");
  x.setAttribute("src", array_Icons[i] );
  x.setAttribute("style", "width: 15px; height: 15px; margin-right: 5px;");

  document.body.appendChild(x);
  document.body.appendChild(br);
}

console.log(document.body.innerHTML)

事实上你可以检查生成的 html(即 document.body.innerHTML ):

<img src="url('submitBtnIcon')" style="width: 15px; height: 15px; margin-right: 5px;"><br><img src="url('addBtnIcon')" style="width: 15px; height: 15px; margin-right: 5px;"><br><img src="url('clearBtnIcon')" style="width: 15px; height: 15px; margin-right: 5px;"><br><img src="url('exportBtnIcon')" style="width: 15px; height: 15px; margin-right: 5px;"><br>

关于base64 图像的 Javascript 数组循环并放置在页面上,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/47562698/

相关文章:

javascript - 如何将这个点击事件函数变成在 div 加载时自动调用的函数?

javascript - 如何使用 jspdf-autotable 打印四个不同的表格

java - JNI 中的二维数组

sql - Spark 内联与。横向 View explode 差异?

c - 使用系统函数运行另一个.cpp文件

javascript - 将图像文件放在 node.js 中的什么位置?

javascript - jQuery 提交需要点击 2 次才能运行

javascript - 为什么 Errors 不能被字符串化?

java - 如何使用JAVA计算标准偏差

javascript - 更改所有图像源 jquery