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

标签 javascript jquery json

我正在尝试通过 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/

相关文章:

java - 从 PHP/MySQL 到 Java/JSON

javascript - 任何显示 ajax 内容 slider 的教程?

javascript - webpack 找不到 bundle.js

javascript - 服务器无响应时如何处理ajax调用

javascript - jquery中如何遍历元素属性值?

json - EC2 实例类型的 AWS Cloudformation 模板错误

PHP - 比较两个 JSON 对象的结构

javascript - 仅当页面上的元素超过两个时,如何向元素添加另一个类?

javascript - 如何在一行中返回 map 箭头函数中的展开运算符

javascript - 通过if条件防止双击事件