jQuery Ajax:在ajax中调用ajax

时间:2013-03-12 10:27:27

标签: jquery ajax

我正在使用此代码作为联系表单: http://spyrestudios.com/coding-a-minimalist-contact-form-with-captcha-spam-protection/

我有这个菜单列表:

<ul class="menu">
  <li class="company"><a href="#"> company</a>
  <ul>
    <li class="aboutus"><a href="#" >aboutus</a></li>
    <li class="contactus"><a href="#" >contactus</a></li>
  </ul>  
  </li>
  <li class="services"><a href="#">services</a></li>
</ul>

我试图用这样的ajax调用联系表单:

$(document).on("click", ".menu li.contactus", function(e) {

  e.stopPropagation();
  $("#contactform").load("contact.php");

});

以下是联系表格代码:

<?php
session_start();
?>

 <div id="wrapper">
<div id="contactwrapper">
<form id="contact" name="contact" method="post" action="contact.php" enctype="multipart/form-data">
    <input type="hidden" name="check" value="01">
    <small>*all form fields are required.</small>

    <label for="name" id="namelabel">Name:<span class="err topp">enter your name</span></label>
    <input type="text" name="name" id="name" class="textinput">


    <label for="email" id="emailabel">E-mail:<span class="err topp">enter a valid e-mail address</span></label>
    <input type="email" name="email" id="email" class="textinput">


    <label for="message" id="msglabel">Message:<span class="err txarea">share some stuff with us</span></label>
    <textarea name="message" id="message" class="msgtextarea"></textarea>


    <img src="captcha.php" id="captchaimg">

    <label for="captcha" id="captchalabel">You're not a spammer, right?<span class="err capter">your CAPTCHA code looks wrong</span></label>
    <input type="text" name="captchavalue" id="captchavalue" class="textcaptcha">


    <section id="subber">
    <a href="javascript:void(0);" name="submitlink" id="submitlink" class="btn">Send Message</a>
    </section>
</form>
</div>
   </div>

    <script type="text/javascript">
     function checkValidEmailAddress(emailAddress) {
     var pattern = new RegExp(/^(("[\w-+\s]+")|([\w-+]+(?:\.[\w-+]+)*)|("[\w-+\s]+")([\w-+]+(?:\.[\w-+]+)*))(@((?:[\w-+]+\.)*\w[\w-+]{0,66})\.([a-z]{2,6}(?:\.[a-z]{2})?)$)|(@\[?((25[0-5]\.|2[0-4][\d]\.|1[\d]{2}\.|[\d]{1,2}\.))((25[0-5]|2[0-4][\d]|1[\d]{2}|[\d]{1,2})\.){2}(25[0-5]|2[0-4][\d]|1[\d]{2}|[\d]{1,2})\]?$)/i);

return pattern.test(emailAddress);
};

var mailsendstatus;
function userSendMailStatus(uname, uemail, umsg, ucaptcha) {
// checking for some valid user name
if(!uname) {
    $("#namelabel").children(".err").fadeIn('slow');
}
else if(uname.length > 3) {
    $("#namelabel").children(".err").fadeOut('slow');       
}

// checking for valid email
if(!checkValidEmailAddress(uemail)) {
    $("#emailabel").children(".err").fadeIn('slow');
}
else if(checkValidEmailAddress(uemail)) {
    $("#emailabel").children(".err").fadeOut('slow');   
}

// checking for valid message
if(!umsg) {
    $("#msglabel").children(".err").fadeIn('slow');
}
else if(umsg.length > 5) {
    $("#msglabel").children(".err").fadeOut('slow');
}

// ajax check for captcha code
$.ajax(
    {
        type: 'POST',
        url: 'captcha_check.php',
        data: $("#contact").serialize(),
        success: function(data) {
            if(data == "false") {
                mailsendstatus = false;
                $("#captchalabel").children(".err").fadeIn('slow');
            }
            else if(data == "true"){
                $("#captchalabel").children(".err").fadeOut('slow');

                if(uname.length > 3 && umsg.length > 5 && checkValidEmailAddress(uemail)) {
                    // in this case all of our inputs look good
                    // so we say true and send the mail
                    mailsendstatus = true;

                    $("#subber").html('<img src="load.gif" alt="loading...">');

                    $.ajax(
                        {
                            type: 'POST',
                            url: 'sendmail.php',
                            data: $("#contact").serialize(),
                            success: function(data) {

                                if(data == "yes") {
                                    alert("aaa");
                                $("#contactwrapper").slideUp(650, function(){
                                    $(this).before("<strong>Yep your mail has been sent!</strong>");
                                });
                                }
                            }
                        }
                    ); // close sending email ajax call 
                } // close if logic for mailsendstatus true
            } // close check CAPTCHA return true
        } // close ajax success callback function
    } // close ajax bracket open
);

return mailsendstatus;
   }

   $(document).ready(function(){
$("#contact").submit(function() { return false; });

$("#submitlink").bind("click", function(e){
    var usercaptvalue = $("#captchavalue").val();
    var subnamevalue  = $("#name").val();
    var emailvalue    = $("#email").val();
    var msgvalue      = $("#message").val();


    var postchecks = userSendMailStatus(subnamevalue, emailvalue, msgvalue, usercaptvalue);
});
  });
</script>

联系表单正在检查验证码并使用jquery ajax发送数据。 因此,php页面中的ajax代码不起作用。

是否可以在此内部调用ajax?

任何帮助都将不胜感激。

1 个答案:

答案 0 :(得分:0)

当你使用load() jQuery加载Html时。

如果您需要javascript,请尝试使用$.getScript()从文件中获取指定的javascript。

您还可以运行iframe来避免这种情况,或尝试将您的联系表单javascript嵌入index页面。