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

时间:2014-07-07 01:02:28

标签: javascript jquery json

我正在尝试通过Javascript动态创建一行文本框,并在JSON中读取文本框的值。稍后,我必须阅读JSON并在textarea中显示值,这应该只通过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/

1 个答案:

答案 0 :(得分:1)

由于您使用的是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=button更改为button以利用input选择器同时循环行来创建数据,而不必过滤掉按钮

您的演示文稿包含无效的html,但<tr>

的顶部版本缺少<th>

DEMO

您出错的地方:

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