Here I am using a contact form. When I click on the submit button instead of displaying "message sent successfully" on the same page, it redirects to blank page. My HTML form
<!-- form element -->
<div class="row">
    <div class="col-md-6 form-group">
        <input name="name" type="text" class="form-control" placeholder="Name" required>
    </div>
    <div class="col-md-6 form-group">
        <input name="email" type="email" class="form-control" placeholder="Email" required>
    </div>
    <div class="col-md-6 form-group">
        <input name="subject" type="text" class="form-control" placeholder="Subject" required>
    </div>
    <div class="col-12 form-group">
        <textarea name="message" class="form-control" rows="3" placeholder="Message" required></textarea>
    </div>
    <div class="col-12">
        <input n id="btnClick" type="submit" class="btn btn-success" value="Send Message">
    </div>
</div>
<!-- end form element -->
My JavaScript code:
$('#btnClick').on('click', function(e){
   e.preventDefault();
   var name = $('input#name').val(),
       email = $('input#email').val(),
       message = $('textarea#message').val(),
       subject = $('input#subject').val()
       formData = 'name=' + name + '&email=' + email + '&message=' + message + '&subject=' +  subject;
    $.ajax({
      type: 'post',
      url: 'mail.php',
      data: formData,
      success: function(results) {
        $('ul#msgSubmit').html(results);
      }
    });
});
And my php code:
<?php
    if ($_SERVER["REQUEST_METHOD"] == "POST") {
        # FIX: Replace this email with recipient email
        $mail_to = ""; // my email here
        
        # Sender Data
        $subject = trim($_POST["subject"]);
        $name = str_replace(array("\r","\n"),array(" "," ") , strip_tags(trim($_POST["name"])));
        $email = filter_var(trim($_POST["email"]), FILTER_SANITIZE_EMAIL);
        $message = trim($_POST["message"]);
        
        if ( empty($name) OR !filter_var($email, FILTER_VALIDATE_EMAIL) OR empty($subject) OR empty($message)) {
            # Set a 400 (bad request) response code and exit.
            http_response_code(400);
            echo "Please complete the form and try again.";
            exit;
        }
        
        # Mail Content
        $content = "Name: $name\n";
        $content .= "Email: $email\n\n";
        $content .= "Message:\n$message\n";
        # email headers.
        $headers = "From: $name <$email>";
    $headers .= 'MIME-Version: 1.0' ."\r\n";
    $headers .= 'Content-Type: text/HTML; charset=utf-8' . "\r\n";
    $headers .= 'Content-Transfer-Encoding: 8bit'. "\n\r\n";
    $headers .= $text . "\r\n";
        # Send the email.
        $success = mail($mail_to, $subject, $content, $headers);
        if ($success) {
            # Set a 200 (okay) response code.
            http_response_code(200);
            echo "Thank You! Your message has been sent.";
        } else {
            # Set a 500 (internal server error) response code.
            http_response_code(500);
            echo "Oops! Something went wrong, we couldn't send your message.";
        }
    } else {
        # Not a POST request, set a 403 (forbidden) response code.
        http_response_code(403);
        echo "There was a problem with your submission, please try again.";
    }
?>
I tried everything change **<input  type="submit" to button**
Use ajax **e.preventDefault();**
and again it redicted me to new page mywebsite.eu/assets/js/mail.php
I dont know how to fix it.
 
     
     
    