0

我是表单的新手,但我觉得我错过了一些简单的东西。除了“错误”警报之外,根本没有“成功”。

这是 index.html 文件中的表单代码。

<form id="contact-form" name="contact-form" method="post">
    <div id="formResponse"></div>

    <label for="name">NAME:</label>
    <input type="text" name="name" id="name" /><br/>

    <label for="email">EMAIL:</label>
    <input type="text" name="email" id="email" /><br/>

    <label for="message">MESSAGE:</label>
    <textarea name="message" rows="20" cols="20" id="message"></textarea><br/>

    <input type="submit" name="submit" value="SEND" class="submit" />
</form>

我的 .js 文件中的 Ajax 代码

$('.submit').click(form_registration);

function form_registration () {

    var input_data = $('#contact-form').serialize(); 

$.ajax({    
    type: 'post',
    url: '../contact.php',
    data: input_data,
    dataType: 'json',
    success: function( msg ){
        alert('SUCCESS!');
    },
    error: function(){ 
        alert('ERROR!');
        alert(input_data);
    }
});   

}

contact.php 文件

< ?php 

    if($_POST) {

    $name = trim($_POST['name']);
    $email = trim($_POST['email']);
    $msg = trim($_POST['msg']);

    <!-- //email address settings -->
    $my_address = "MY EMAIL ADDRESS GOES HERE";
    $headers = "From: ".$email;
    $message = "Contact name: $name\nContact Email: $email\nContact Message: $msg";

    $to = $my_address;

    if ( $name == "")
    {
        echo 'Name field is required';
        <!-- $result = "Name field is required"; -->
    }
    else if (!preg_match("/^[_a-z0-9-]+(\.[_a-z0-9-]+)*@[a-z0-9-]+(\.[a-z0-9-]+)*(\.[a-z]{2,4})$/", $email))
    {
        echo 'Enter a valid email address';
        <!-- $result = "Enter a valid email address"; -->
    }
    else if ( strlen($msg) < 10 )
    {
        echo 'Write more than 10 characters';
        <!-- $result = "Write more than 10 characters"; -->
    }

    else
    {
    mail($to, $subject, $message, $headers);
    echo "Your mail has been sent succesfully!";
    }

    if ($javascript_enabled == "true") {
        echo 'javascript enabled';
        die();
    }   
}
?>

这是示例。点击底部的联系链接。非常感谢您的帮助!

4

2 回答 2

2

试试这个代码。我已经对您的代码进行了一些更改,并且现在可以正常运行。

联系方式.html

<head>
    <script type="text/javascript" src="js/jquery.js"></script>
</head>
<body>
    <form id="contact" action="contact.php" name="contact" method="post">

<div id="formResponse"></div>

<label for="name">NAME:</label>
<input type="text" name="name" id="name" /><br/>

<label for="email">EMAIL:</label>
<input type="text" name="email" id="email" /><br/>


<label for="sub">SUBJECT</label>
<input type="sub" name="sub" id="subject" /><br/>

<label for="message">MESSAGE:</label>
<textarea name="message" rows="20" cols="20" id="message"></textarea><br/>

<input type="submit" name="submit" value="SEND" class="submit" />
</form>
</body>

联系方式.php

<?php
 if($_POST) {

    $name = trim($_POST['name']);
    $email = trim($_POST['email']);
    $msg = trim($_POST['message']);
    $subject = trim($_POST['sub']);
    //email address settings
    $my_address = "nitish@kinsh.in";
    $headers = "From: ".$email;
    $message = "Contact name: $name\nContact Email: $email\nContact Message: $msg";
    $to = $my_address;
    if ( $name == "")
    {
        echo 'Name field is required';
        $result = "Name field is required"; 
    }
    else if (!preg_match("/^[_a-z0-9-]+(\.[_a-z0-9-]+)*@[a-z0-9-]+(\.[a-z0-9-]+)*(\.[a-z]{2,4})$/", $email))
    {
        echo 'Enter a valid email address';
        $result = "Enter a valid email address"; 
    }
     else if( strlen($subject) == "")
    {
        echo 'Please Write Subject';
        $result = "Please Write Subject"; 
        }
        else if ( strlen($msg) < 10 )
    {
        echo 'Write more than 10 characters';
        $result = "Write more than 10 characters"; 
    }
    else
    {
        mail($to, $subject, $message, $headers);
        echo "Your mail has been sent succesfully!";
    }
}
?>

联系.js

$('.submit').click(form_registration);
function form_registration () {

var input_data = $('contact-form').serialize(); 
            $.ajax({
            type: 'post',
            url: 'contact.php',
            data: input_data,
            dataType: 'json',
            success: function( msg ){
            alert('SUCCESS!');
        },
        error: function(){
            alert('ERROR!');
            alert(input_data);
        }
});  
 return false; 
}
于 2013-10-28T13:42:14.713 回答
0

好的,首先你必须在右括号之前添加 toreturn false以防止提交form_registration()}form

其次,您contact.php没有有效的开始PHP标签更改< ?php<?php

搏一搏...

于 2012-05-16T03:10:23.333 回答