doubi2145 2012-10-01 18:14
浏览 38
已采纳

通过AJAX提交的表单,返回JSON响应[关闭]

I have my form set up and the jquery written but I've have no idea what to write for the PHP that should be in mail.php.

Any help would be awesome

HTML:

<form id="contact-form" action="mail.php" method="GET">
   <fieldset>
       <label for="email">Email</label>
       <input type="email" name="email" id="email" required="">
   </fieldset>

   <fieldset>
       <label for="enquiry">Message</label>
       <textarea name="enquiry" id="enquiry" width="100%" height="100px" required=""></textarea>
   </fieldset>

   <fieldset>
        <input type="submit" name="submit" value="Submit Enquiry">
   </fieldset>

</form>

JQUERY:

$(document).ready(function(){

$("#contact-form").submit( function (){
    $.getJSON('mail.php',$(this).serialize(), function(data) { 
        if(data['success'] == 1)
        {
            $('#contact-form').html("<p class=\"success\">"+data['message']+"</p>");
        }
        else
        {
                alert(""+data['message']+"");
                $('#contact-form *').removeClass('error');
                for(key in data.errors)
                {
                    $('#'+key).addClass('error');
                }
        }
    });
    return false;
});

});

PHP:

?
  • 写回答

1条回答 默认 最新

  • dsiv4041 2012-10-01 18:24
    关注

    Use this in server-side

    parse_str($_GET["data"],$array);
    
    mail($array["email"]);
    

    in jquery

     $.getJSON('mail.php',{"data":$(this).serialize()}, function(data) { ...
    
                      or
    
    var data=$("#contact-form").serialize();
    $.ajax(
    url:'mail.php';
    {data:{"data":data},
    datatype:"json",
    success:(function(data){
    
       if(data['success'] == 1)
            {
                $('#contact-form').html("<p class=\"success\">"+data['message']+"</p>");
            }
            else
            {
                    alert(""+data['message']+"");
                    $('#contact-form *').removeClass('error');
                    for(key in data.errors)
                    {
                        $('#'+key).addClass('error');
                    }
            } 
        })
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥50 汇编语言除法溢出问题
  • ¥50 C++实现删除N个数据列表共有的元素
  • ¥15 Visual Studio问题
  • ¥15 state显示变量是字符串形式,但是仍然红色,无法引用,并显示类型不匹配
  • ¥20 求一个html代码,有偿
  • ¥100 关于使用MATLAB中copularnd函数的问题
  • ¥20 在虚拟机的pycharm上
  • ¥15 jupyterthemes 设置完毕后没有效果
  • ¥15 matlab图像高斯低通滤波
  • ¥15 针对曲面部件的制孔路径规划,大家有什么思路吗