javascript - 将输入值插入 JSON 数组

标签 javascript html arrays json

我正在尝试将一些值从输入文本框推送到 JSON 数组。这是我尝试过的

代码:

<!DOCTYPE html>
<html>
<body>

<input id="studentnumber" placeholder="Student Number"></input>
<input id="status" placeholder="Status"></input>
<button id="bt1" onclick="newUser()">Validate</button>
<p id="demo"></p>

<script type="text/javascript">

//Array
var jsonStr = 
    '{"G11S":[{"StudentNumber":"1","status":"Pass"},{"StudentNumber":"2","status":"Pass"},{"StudentNumber":"3","status":"Pass"}]}';


function newUser(){

    x = document.getElementById("studentnumber").value;

    //Debug
    console.log(x);

    var obj = JSON.parse(jsonStr);
    obj['G11S'].push({"StudentNumber": "4","status": "Member"}); // <~~ What am I Supposed to replace the "4" with and the "Member aswell"

    jsonStr = JSON.stringify(obj);
    console.log(jsonStr);
}


</script>

</body>
</html>

因此,我尝试通过定义变量 (x) 将“x”插入数组以获取输入文本框的值:

x = document.getElementById("studentnumber").value;

尝试将其推送到第 25 行:

obj['G11S'].push({"StudentNumber": "4","status": "Member"});

最佳答案

您必须获取输入值并将其存储在对象变量中,然后将该变量推送到 JSON 数组中:

function newUser(){
  var user = {};

  user.StudentNumber = document.getElementById("studentnumber").value;
  user.status = document.getElementById("status").value;

  //Debug
  console.log(user);

  var obj = JSON.parse(jsonStr);
  obj['G11S'].push(user);

  jsonStr = JSON.stringify(obj);
  console.log(jsonStr);
}

关于javascript - 将输入值插入 JSON 数组,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35728641/

相关文章:

java - 在嵌套循环后填充数组

javascript onclick 事件在带有 SQL 驱动数据的 Chrome 中不起作用

javascript - 在收到来自 react 客户端的大量请求后,带有express的socket.io速度变慢

html - 使用CSS添加按钮按下效果

php - 将链接转换成图片

java - 如何从 spring Controller 重定向到本地页面?

javascript - 如何将电子邮件的值动态写入json文件?

javascript - 为什么这个 getElementById 函数不起作用?

javascript - 使用javascript获取输入数组键值的最佳方法

Java ArrayLists 到 JList