如何使用Javascript而不是jQuery从HTML表单数据生成JSON列表?

时间:2015-08-06 00:54:14

标签: javascript html json forms

很抱歉,如果这样的问题真的很烦人;我试图在不打扰任何人的情况下解决这个问题,但我是一个初学者而且我完全被难倒了。这是我到目前为止所拥有的。我想从名为" paymentform"的表单中提取数据。并生成一个JSON列表,我可以在REST调用中发布。我的老板要我用JavaScript而不是jQuery专门做这件事。我该怎么做?



function toggleVisibility(id) {
  var e = document.getElementById(id);
  if (id == "creditCard") {
    document.getElementById("creditCard").checked = true;
    document.getElementById("eCheck").checked = false;
    if (document.getElementById("cardinfo").style.display == "none") {
      document.getElementById("cardinfo").style.display = "block";
      document.getElementById("bankinfo").style.display = "none";
      document.getElementById("cardnumberid").setAttribute("required", true);
      document.getElementById("expdateid").setAttribute("required", true);
      document.getElementById("cvvnumberid").setAttribute("required", true);
      document.getElementById("accountnameid").removeAttribute("required");
      document.getElementById("routingnumberid").removeAttribute("required");
      document.getElementById("banknameid").removeAttribute("required");
      document.getElementById("accountnumberid").removeAttribute("required");
    }
  }
  if (id == "eCheck") {
    document.getElementById("creditCard").checked = false;
    document.getElementById("eCheck").checked = true;
    if (document.getElementById("bankinfo").style.display == "none") {
      document.getElementById("cardinfo").style.display = "none";
      document.getElementById("bankinfo").style.display = "block";
      document.getElementById("cardnumberid").removeAttribute("required");
      document.getElementById("expdateid").removeAttribute("required");
      document.getElementById("cvvnumberid").removeAttribute("required");
      document.getElementById("accountnameid").setAttribute("required", true);
      document.getElementById("routingnumberid").setAttribute("required", true);
      document.getElementById("banknameid").setAttribute("required", true);
      document.getElementById("accountnumberid").setAttribute("required", true);
    }
  }
}

function setValue() {
  document.getElementById("creditCard").checked = true;
  document.getElementById("eCheck").checked = false;

  document.getElementById("cardinfo").style.display = "block";
  document.getElementById("bankinfo").style.display = "none";
  document.getElementById("cardnumberid").setAttribute("required", true);
  document.getElementById("expdateid").setAttribute("required", true);
  document.getElementById("cvvnumberid").setAttribute("required", true);
  document.getElementById("accountnameid").removeAttribute("required");
  document.getElementById("routingnumberid").removeAttribute("required");
  document.getElementById("banknameid").removeAttribute("required");
  document.getElementById("accountnumberid").removeAttribute("required");
}

function submitForm() {
  var myForm = document.getElementsByName("paymentform")[0];
}

body {
  margin-top: 100px;
  margin-left: 200px;
  margin-right: 350px;
  font-family: Helvetica;
  font-size: 90%;
}
h1 {
  font-family: Helvetica;
  font-size: 150%;
}
h2 {
  font-family: Helvetica;
  font-size: 110%;
}
p {
  font-family: Helvetica;
}

<!DOCTYPE html>
<html>

<head>
  <title>Payment Information</title>
  <link rel="stylesheet" type="text/css" href="CreditCardAndECheckTest.css">
  <script src="CreditCardAndECheckTest.js"></script>
</head>

<body onload="setValue()">
  <h1>Payment Profile</h1>
  <hr>
  <p>Enter the information for each field listed below.</p>
  <h2>Billing Information</h2>
  <form name="paymentform" onsubmit="return window.submitForm()" method="post">
    First Name:
    <input type="text" name="firstname" required>&nbsp; &nbsp;&nbsp; &nbsp; Last Name:
    <input type="text" name="lastname" required>
    <br>
    <br>Company Name:
    <input size="83px" type="text" name="companyname" required>
    <br>
    <br>Address 1:
    <input size=T "30px" type="text" name="address1" required>&nbsp; &nbsp;&nbsp; &nbsp;
    <br>
    <br>Address 2:
    <input size="30px" type="text" name="address2" required>
    <br>
    <br>City:
    <input type="text" name="cityname" required>&nbsp; &nbsp;&nbsp; &nbsp; State/Province:
    <input type="text" name="statename" required>
    <br>
    <br>Zip/Postal Code:
    <input size="5px" type="text" name="zippostalcode" required>&nbsp; &nbsp; &nbsp; Country:
    <input type="text" name="country" required>
    <br>
    <br>Email:
    <input type="text" name="email" required>&nbsp; &nbsp; &nbsp; Phone:
    <input type="text" name="phonenumber" required>&nbsp; &nbsp; &nbsp; Fax:
    <input type="text" name="faxnumber">
    <br>
    <h2>Payment Information</h2>
    Payment Type &nbsp;
    <input id="creditCard" onclick="toggleVisibility('creditCard')" checked type="radio" />Credit Card &nbsp;
    <input id="eCheck" onclick="toggleVisibility('eCheck')" type="radio" />Bank Account
    <br>
    <br>
    <div id="cardinfo" style="display:block">
      Accepted Methods: American Express, Discover, JCB, Mastercard, Visa
      <br>
      <br>Card Number:
      <input id="cardnumberid" type="text" name="cardnumber" required>
      <br>
      <br>Expiration Date:
      <input id="expdateid" type="text" name="expdate" required>(mmyy)
      <br>
      <br>CVV (3-digit number on the back of the card, if applicable):
      <input id="cvvnumberid" type="text" name="cvvnumber" required>
    </div>
    <div id="bankinfo" style="display:none">
      Name on Account:
      <input id="accountnameid" size="30px" type="text" name="accountname" required>&nbsp; &nbsp; &nbsp; Account Type:
      <select>
        <option value="checking">Checking</option>
        <option value="savings">Savings</option>
        <option value="businesschecking">Business Checking</option>
      </select>
      <br>
      <br>9-digit Routing Number:
      <input id="routingnumberid" type="text" name="routingnumber" required>&nbsp; &nbsp; &nbsp; Account Number:
      <input id="accountnumberid" type="text" name="accountnumber" required>
      <br>
      <br>Bank Name:
      <input id="banknameid" size="30px" type="text" name="bankname" required>
    </div>
    <br>
    <center>
      <input type="submit" value="Submit">
    </center>
  </form>
</body>

</html>
&#13;
&#13;
&#13;

1 个答案:

答案 0 :(得分:1)

tl; dr:I've provided a jsBin with a working example of your code

因此,首先,jQuery存在以规范奇怪的浏览器行为(主要是解决IE问题)并提供做常见事情的简写方法。多次写出document.getElementById()既累又不可读。我添加了这个简单的函数,使这一点变得更容易:

function byId(element) {
  return document.getElementById(element);
}

byId('firstname') // <input type="text" id="firstname" required>

我还将所有name属性更改为ID。调用getElementsByNames()有点不稳定,所以我个人会避免它。

最后,这里是如何设置要在POST请求(或其他)中传递的数据。

function submitForm() {
  var cardId = byId("cardinfo");
  var payment = {};
  var data = {};

  if (getCSS(cardId, 'display') == "block") {
    payment = {    
      num: byId("cardnumberid").value,
      exp: byId("expdateid").value,
      cvv: byId("cvvnumberid").value      
    };
  } else {
    payment = {
      accountName: byId("accountnameid").value,
      routingNum: byId("routingnumberid").value,
      bankName: byId("banknameid").value,
      accountNum: byId("accountnumberid").value
    };
  }

  data = {
    first: byId('firstname').value,
    last: byId('lastname').value,
    company: byId('companyname').value,
    addr1: byId('address1').value,
    addr2: byId('address1').value,
    city: byId('cityname').value,
    state: byId('statename').value,
    zip: byId('zippostalcode').value, 
    country: byId('country').value,
    email: byId('email').value,
    phone: byId('phonenumber').value, 
    fax: byId('faxnumber').value,
    payment: payment
  };


  data = JSON.stringify(data);
  console.log(data);  

  // Prevent the form from submitting and refreshing the page  
  return false;
}

您需要创建要以某种方式发送的对象,然后需要在其上调用JSON.stringify(objectName)。这会将对象变成一个简单的字符串。当您从请求中获取数据时,您通常需要调用JSON.parse(objectName)才能操作数据。

哦,额外的功劳:

调用此方法不起作用:

if (document.getElementById("bankinfo").style.display == "none") {...

document.getElementById().style只设置样式。我创建了以下wee函数来帮助:

function getCSS(element, attr) {
  return window.getComputedStyle(element).getPropertyValue(attr);
}

查看MDN's documentation on getPropertyValue() for more info