each
является допустимой функцией, а getElementsByClassName () возвращает HTMLCollection , которая не поддерживает forEach.
Мы также можем использовать Array.from для преобразования коллекции HTMLC в массив и использования forEach в списке.
Array.from(document.getElementsByClassName("filed")).forEach(...
или использование для цикла while.
for (let i = 0; i < elements.length; i++) {...}
function save() {
var els = document.getElementsByClassName("field");
const formdata = {};
[].forEach.call(els, function (el) {
formdata[el.id] = el.value;
document.getElementById("input" + el.id).value= el.value;
});
if(typeof Storage !== "undefined") {
alert('No localStorage support');
return;
}
localStorage.setItem("formdata", JSON.stringify(formdata));
console.log(localStorage.getItem('formdata'));
}
<table style="width: 50%" align="center" cellpadding="5" cellspacing="5">
<tr>
<th>Date</th>
<th>Time</th>
<th>Title</th>
<th>Check</th>
</tr>
<tr>
<td id="inputDate"> </td>
<td id="inputTime"> </td>
<td id="inputTitle"> </td>
<td style="text-align:center"><input name="Checkbox1" type="checkbox" /></td>
</tr>
</table>
<div id="getinput">
<table style="width:100%;" align="center" cellpadding="5" cellspacing="5">
<tr>
<td style="border:none">Date:</td>
<td style="border:none"><input class="field" id="Date" name="Text1" type="date"></td>
</tr>
<tr>
<td style="border:none">Time:</td>
<td style="border:none"><input class="field" id="Time" name="Text1" type="time"></td>
</tr>
<tr>
<td style="border:none">Title:</td>
<td style="border:none"><input class="field" id="Title" name="Text1" type="text" placeholder="Meeting details"></td>
</tr>
<tr style="text-align:center">
<td style="border:none" colspan="2"><input name="btc" type="button" value="Cancel" onclick="cancel()">
<input name="bts" type="button" value="Save" onclick="save()"></td>
</tr>
</table>