doudun6928 2014-05-07 19:06
浏览 64
已采纳

Ajax表单onsubmit停止刷新

I have one page lets call it "X.php" that i use that calls another page "Y.php" with the xmlhttp.open() function.

At the moment i have a form in page Y.php, and i would like to prevent it from refreshing because once i click on the submit button, my form dissapear.

I tryed with Jquery 'event.preventDefault()' in page X.php but nevertheless it didnt work.

Does anyone know a solution?

while($row = mysql_fetch_array($query)) {

            echo "    <h2>Update your personal settings</h2>

            <form action='' id='target' method='POST'>
                Surname: <input type=text name='lid_voornaam' value='".$row['lid_voornaam']."'><br/>
                Name: <input type=text name='lid_naam' value='".$row['lid_naam']."'><br/>
                Email: <input type=text name='lid_email' value='".$row['lid_email']."'><br/>    
                <input type='submit' value='Whatever' id='test1'/> 
            </form>";
    }

Java script:

<script type="text/javascript">
$(document).ready(function(){
   $("#test1").click(function(event){
    event.preventDefault();
  });

});

  • 写回答

2条回答 默认 最新

  • droxlzcgnr639823 2014-05-07 19:13
    关注

    In your form tag. Add onSubmit="return false;

    <form action='' id='target' method='POST' onSubmit="return false;>
       Surname: <input type=text name='lid_voornaam' value='".$row['lid_voornaam']."'><br/>
       Name: <input type=text name='lid_naam' value='".$row['lid_naam']."'><br/>
       Email: <input type=text name='lid_email' value='".$row['lid_email']."'><br/>    
       <input type='submit' value='Whatever' id='test1'/> 
    </form>
    

    As @andrew mentions. Your php script will generate multiple <form> tags which will all have the same id id='target'. This can cause problems on your page as that isnt valid html

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?