gpt4 book ai didi

javascript - 如何从 JSON 中动态创建的文本框行获取值

转载 作者:行者123 更新时间:2023-12-03 12:17:41 25 4
gpt4 key购买 nike

我正在尝试通过 Javascript 动态创建一行文本框并读取 JSON 中文本框的值。后来,我必须读取 JSON 并在文本区域中显示值,这只能通过 jquery 和 javascript 来实现。

我能够动态创建文本框,但无法读取 JSON 中的值。当我使用 jQuery 部分(下面提到)时,动态创建文本框的 javascript 不起作用。请提供任何建议。

<table id="myTable">
<th>Name</th>
<th>Age</th>
<th>Gender</th>
<th>Occupation and Employer</th>
<th>Add</th>
<tr>
<td><input type="text" id="txtName" /></td>
<td><input type="text" id="txtAge" /></td>
<td><input type="text" id="txtGender" /></td>
<td><input type="text" id="txtOccupation" /></td>
<td><input type="button" id="btnAdd" class="button-add" onClick="insertRow()" value="add"></input></td>
<td><input type="button" id="btnSave" class="button-add" value="Save"></input> </td>
</tr>
</table>

<script>
var index = 1;
function insertRow()
{
var table=document.getElementById("myTable");
var row=table.insertRow(table.rows.length);
var cell1=row.insertCell(0);
var t1=document.createElement("input");
t1.id = "txtName"+index;
cell1.appendChild(t1);
var cell2=row.insertCell(1);
var t2=document.createElement("input");
t2.id = "txtAge"+index;
cell2.appendChild(t2);
var cell3=row.insertCell(2);
var t3=document.createElement("input");
t3.id = "txtGender"+index;
cell3.appendChild(t3);
var cell4=row.insertCell(3);
var t4=document.createElement("input");
t4.id = "txtOccupation"+index;
cell4.appendChild(t4);
index++;
}


$(document).ready(function(){
$("#btnsave").click(function ()
{

alert("Hi");
var dataToSend={
'Name':[],
'Age':[]};
dataToSend.Name.push({$("txtName").val().trim()});
dataToSend.Age.push({$("txtAge").val().trim()});
localStorage.setItem('DataToSend', JSON.stringify(DataToSend));

var restoredSession = JSON.parse(localStorage.getItem('dataToSend'));

// Now restoredSession variable contains the object that was saved
// in localStorage
console.log(restoredSession);

alert(restoredSession);

});
});

JSFiddle:http://jsfiddle.net/S7c88/

最佳答案

由于您使用的是 jQuery,因此您可以使用 clone() 等方法大大简化整个过程。 。

这是一个工作示例,我创建了一个行对象数组。由于您没有在表单中执行此操作,因此我删除了 ID 并仅使用 data-name .

var $row;

function insertRow() {
$('#myTable').append($row.clone());
}
$(function () {
$row = $('tr').eq(1).clone(); /* clone first row for re-use*/
$('#myTable').on('click', '.btnSave', function () {
var dataToSend = [];
$('tr:gt(0)').each(function () {
var data = {};
$(this).find('input').each(function () {
data[$(this).data('name')] = this.value
});
dataToSend.push(data);
});
/* display data in textarea*/
$('#output').val(JSON.stringify(dataToSend, null, '\t'))
});
}) ;

我改变了你的input type=buttonbutton利用 input选择器同时循环行以创建数据,而不必过滤掉按钮

您的演示有无效的 html,缺少 <tr>顶部套装<th>

DEMO

一些你出错的地方:

  • $("txtName")选择器无效
  • 尝试收集数据时没有行引用

关于javascript - 如何从 JSON 中动态创建的文本框行获取值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24601799/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com