2 回答
TA贡献1801条经验 获得超16个赞
一种解决方案是交互所有对象属性并为每个属性创建一个标签和输入,然后将其附加到 DOM。这是一些示例代码:
var config = {
first: {
value: 'example', type: 'text', label: 'Name'
},
second: {
value: 'some', type: 'text', label: 'Family' }
};
Object.keys(config).forEach(key => {
var container = document.getElementById("input-boxes");
var inputEl = document.createElement("input");
var label = document.createElement("LABEL");
label.innerHTML = config[key].label;
inputEl.type = config[key].type;
inputEl.value = config[key].value;
container.appendChild(label); // put label into the DOM
container.appendChild(inputEl); // put it into the DOM
});
下面是这个例子在现实中的工作原理:
https://jsfiddle.net/ea65f4sq/3/
TA贡献1780条经验 获得超4个赞
https://codepen.io/themustafaomar/pen/YzXmqMY?editors=1011
var config = {
first: {
value: "example",
type: "text",
label: "Name"
},
second: {
value: "some",
type: "text",
label: "Family"
}
};
Object.keys(config).forEach((key) => {
var container = document.createElement("div");
var field = document.createElement("input");
var label = document.createElement("label");
label.textContent = config[key].label;
field.value = config[key].value;
field.setAttribute("type", config[key].type);
container.appendChild(label);
container.appendChild(field);
document.body.appendChild(container);
});
- 2 回答
- 0 关注
- 88 浏览
添加回答
举报