具有 JSON 响应的 AJAX 示例,其中包含正在传递的对象


AJAX example with JSON Response with object being passed

我很难使用 AJAX 将关联数组发送到 php 文件。有些事情我不清楚。这是我从输入标签形式制作数组的代码,但我不知道如何发送它并在 php 中解释它。

<script type="text/javascript">
$(document).ready(function(){
  $(':submit').on('click', function() { // This event fires when a button is clicked
      var theData = {};
      $(":input:not(:button)").each(
        function(index){  
            var input = $(this);
            theData[input.attr('name')] = input.val();
        }
      );
      $.ajax({ // ajax call starts
          url: "http://www.aberlechiropractic.com/meningealrelease/modifydoctors/modifydoctors3.php",
          data: theData,
          dataType: 'json',
          success: function(data)
          {
              $('#wines').html(''); // Clear #wines div
              $('#wines').append('Data Received: ' + data.name+'   '+data.address + '<br/>');
          }
      });
      return false; // keeps the page from not refreshing 
  });
});
</script>
<body>
  <form>
    <input type="text" name="name" id="name" value="Jeff Aberle"/>
    <input type="text" name="address1" id="address1" value="4710 East Broadway"/>
    <button type="submit" name="updatedoctor" id="updatedoctor" value="all">All</button>
  </form>
</body>

这是我的 php 代码:

<?php
$name = $_GET['name'];
$address1 = $_GET['address1'];
$array = array($button, $address1);
print json_encode($array);
?>

啊,现在一切正常。我在这里编辑了所有代码来完成这项工作。

<?php
// Get value of clicked button
$name = $_GET['name'];
$address1 = $_GET['address1'];
$array = array(
    "name"    => $name,
    "address"  => $address1,
);
print json_encode($array);
?>

我还有一个带有 id=wine 的div .这是我忘了展示的另一件事。但是,这是数据返回到并显示没有名称的地方。

你收集值的jQuery代码是正确的,尽管.serialize()会简化它。

要在 PHP 中检索值,这与表单正常提交相同。他们在$_GET['name']$_GET['address1']. theData只是包含对象的Javascript变量的名称,它不是发送给PHP的属性名称。

要发送数据:我假设您要发送表单的结果?为此,首先您需要向页面添加一个提交按钮。这应该放在您的表格中以提交代码。

其次,您似乎缺少在 AJAX 成功响应中引用的<div id="wine">,因此您需要添加它。

试试这个,你必须在表单中添加按钮才能触发操作:

<script type="text/javascript">
$(document).ready(function(){
  $('#submit').live('click', function() {
      var theData = {};
      $(":input:not(:button)").each(
        function(index){  
            var input = $(this);
            theData[input.attr('name')] = input.val();
        }
      );
      $.ajax({
          url: "http://www.aberlechiropractic.com/modifydoctors3.php",
          data: theData,
          dataType: 'json',
          success: function(data)
          {
              $('#wines').html(''); // Clear #wines div
              $('#wines').append('Data Received: ' + data + '<br/>');
          }
      });
      return false; // keeps the page from not refreshing 
  });
});
</script>
<body>
  <form>
    <input type="text" name="name" id="name" value="Jeff Aberle"/>
    <input type="text" name="address1" id="address1" value="4710 East Broadway"/>
    <input type="button" id="submit" value ="send"/>
  </form>
</body>


<?php
$button = $_GET['theData'];
$array = array($button.name, $button.address1, $button.state);
print json_encode($array);
?>

抱歉,我在手机上,所以这是一个简短的答案,但请使用序列化

http://api.jquery.com/serialize/

    $('form').on('submit', function(){
      $data = $(this).serialize();
      //send via ajax
      return false;
    })