1

ajaxを使用してフォームを投稿しようとしていて、正常に機能しています...しかし、フォームを自動送信しようとすると、フォームが機能しません...送信ボタンを押すと..問題ありません..しかし、setInterval(" submitform();", 5000); ajax は機能しません (つまり、ページをリロードします)。

ajax.js

$(document).ready(function(){
    $('#form1').submit(function(){
        $.ajax({
            url : 'inserir.php',
            type : 'POST',
            data : $('form').serialize(),
            success: function(data){
                $('#resultado').html(data);
            }
        });
        return false;
    });
})

form.html

<html>
<head>
    <script type="text/javascript" src="ajax.js" ></script>
</head>
<body>
<form id="form1" method="POST">
    Código: <br />
    <input type="text" name="idVeiculo" id="idVeiculo" value="1"/>
    <br /><br />
    Nome: <br />
    <input type="text" name="nome" id="nome" /><input type="submit">
</form>

<div id="resultado"></div>
 <script type="text/javascript">

    window.onload=function(){
    setInterval("submitform();", 5000);
    }
    function submitform(){ document.getElementById('form1').submit(); }

</script>
</body>
</html>

したがって、ボタンを押すと正常に動作します...その自動送信機能を使用すると、データをphpファイルに投稿するだけでなく、ページをリロードします。

助けてくれてありがとう!!

4

1 に答える 1

5

MDN から

https://developer.mozilla.org/en-US/docs/Web/API/HTMLFormElement.submit

フォームの onsubmit イベント ハンドラー (たとえば、onsubmit="return false;") は、Gecko ベースのアプリケーションからこのメソッドを呼び出したときにトリガーされません。一般に、HTML ユーザー エージェントによって呼び出されることは保証されていません。

ajax呼び出しを関数に分けて、タイムアウト関数で呼び出すだけです

$(document).ready(function(){
    $('#form1').submit(ajax);
})
function ajax(){
        $.ajax({
            url : 'inserir.php',
            type : 'POST',
            data : $('form').serialize(),
            success: function(data){
                $('#resultado').html(data);
            }
        });
        return false;
}
...
window.onload=function(){
    setInterval(ajax, 5000);
}
于 2013-10-13T22:21:06.793 に答える