javascript - 通过 JQuery $.post 将 JavaScript 数组传递给 PHP

标签 javascript php jquery ajax json

这段代码获取所有表单变量并通过 AJAX 将它们发送到 PHP 脚本。但我希望 PHP 脚本的计算结果通过 JSON 编码数组返回到 javascript,格式为 "post":{"uname":"someNamefromForm","email":"someEmail","fname":"namefromtheform","lname":"lastnamefromform" 我现在得到的输出是“uname=e&email=e&fname=e&lname=euname”..这是我想要在页面底部显示的 JSON 数组,用于调试目的。谁能告诉我如何格式化它

这是我的 HTML 表单

  <div id="wrapper">
      <h2> Validation with AJAX,JQuery,JSON and PHP</h2>
          <div class="form-container">    
              <span id="ajax-message"></span>

              <form id="ajax-form" onsubmit="return false;">
                  <p class="legend">All fields marked with an asterisk are required.</p>

                  <fieldset>
                      <legend>User Details</legend>
                      <div>
                        <label for="uname">Username <em>*</em></label> 
                        <input id="uname" type="text" name="uname" value=""  />
                      </div>
                      <div>
                        <label for="email">Email Address <em>*</em></label> 
                        <input id="email" type="text" name="email" value="" />
                      </div>
                      <div>
                        <label for="fname" class="error">First Name <em>*</em></label> 
                        <input id="fname" type="text" name="fname" value="" size="50" class="error"/>
                        <p class='note'>All error message go here </p> 
                      </div>
                      <div>
                        <label for="lname">Last Name <em>*</em></label> 
                        <input id="lname" type="text" name="lname" value="" size="50" />
                      </div>
                  </fieldset>

                  <div class="buttonrow">
                      <input type="submit" value="Submit This Form via AJAX" class="button" />  
                      <input type="button" value="Start Again" class="button" />
                      <a >Refresh this Page</a>
                  </div>
              </form>
          </div> 
      <h3>JSON Array</h3>
      <pre id='debug'></pre>
  </div>

这是我的 JavaScript

$("#ajax-form").submit(function(){
          var variableToSend = $(this).serialize();
          $.post(
            'ajaxformval_post.php', 
            {variable: variableToSend}, 
            function(data){$("#debug").html(data)},
            "json"
          );
      })

这是 php

<?php
    $variable = $_POST['variable'];

    echo json_encode($variable);

    /*$json = array(
        'booleanFlag' => TRUE,
        'someText' => "AJAX should be renamed AJAJ",
        'anArrayOfData' => array('name' => 'Mickey', 'ears' => 'very Big') 
    );*/

 ?>

最佳答案

您可以像这样直接发送序列化变量:

$("#ajax-form").submit(function(){
      var variableToSend = $(this).serialize();
      $.post(
        'ajaxformval_post.php', 
         variableToSend, 
        function(data){$("#debug").html(data)},
        "json"
      );
  });

然后在服务器端简单地输出 json_encoded 的帖子:

<?php
    $variable = $_POST;

    echo json_encode($variable);
 ?>

关于javascript - 通过 JQuery $.post 将 JavaScript 数组传递给 PHP,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/22581259/

相关文章:

javascript - 范围错误: Maximum call stack size exceeded when try Compilation in Solidity

php - 阻止 PHP PDO 清除每行提取的变量

PHP递归函数不循环更深

javascript - 调整 div 大小时调整字体大小

jquery - Fancybox - onCleanup 中的 jQuery

javascript - 如果没有浏览器刷新,Skrollr 不会产生动画

javascript - Bootstrap 中输入的必需属性不起作用

javascript - 浏览器内音频播放器如何工作?

javascript - 使用 $http.post 和 resangular post 时出现 SyntaxError : Unexpected token F,

PHP session ,为什么 session_start() 需要多次?