0

我有两个带有 id 的表单,formAcomments想通过 AJAX 提交它们。但是这里的ifandelse不检查表格。我总是很警觉hello3

JS:

function submitformbyajax() {
    var currentForm = $(this);
    if (currentForm.attr("id") == 'formA') {
        $.ajax({
            type: 'post',
            url: 'commentformhandler.php',
            data: $("form").serialize(),
            success: function() {
                $("#refresh").load("commentform.php #refresh");
            }
        });
    } else if (currentForm.attr("id") == 'comments') {}
    alert("hello3");
    return false;
}

该函数由

    <div>
    <form name="formA" id="formA" action="" method="" onsubmit="return     submitformbyajax();">
        <textarea name="comment" id="commentform" style="width:90%; height:45px;"></textarea>
        <input type="submit" name="submit" value="submit" id="submitbtn" />
        <input type="hidden" name="onid" value="2" id="submitbtn"/>
    </form>
</div>

这是完整的演示页面....

<?php

?>
<html>
<head>
<script src="http://ajax.googleapis.com/ajax/libs/jquery/1.10.1/jquery.min.js">   </script>
<script>
    function submitformbyajax (){
var currentForm = $(this);
  if (currentForm.attr("id") == 'formA' ) {
        $.ajax({type: 'post',
                url: 'commentformhandler.php',
                data: $("form").serialize(),
                success: function(){
                $("#refresh").load("commentform.php #refresh");
                alert ("hello1");
                }
        } );
}
else if  (currentForm.attr("id") == 'comments') {
        alert("hello2");
    }
    alert ("hello3");
    return false;
}
</script>
    <title>
        comment forms..
    </title>
</head>
<body>
<div>
    <form name="formA" id="formA" action="" method="" onsubmit="return submitformbyajax();">
        <textarea name="comment" id="commentform" style="width:90%; height:45px;"></textarea>
        <input type="submit" name="submit" value="submit" id="submitbtn" />
        <input type="hidden" name="onid" value="2" id="submitbtn"/>
    </form>
</div>
<div id="refresh">
    <?php
        include_once('databaseconnection.php');
        $selectdata=mysql_query("select * from `fetwork_view` ");
        while($selectedinarray=mysql_fetch_array($selectdata)){ ?>
            <table>
                <tr>
                    <td>
                        <?=$selectedinarray['view']?>
                    </td>
                </tr>
                <tr>
                    <td>
        <form name="comment" id="comments" action="" method="">
        <textarea name="comment" id="commentform" style="width:70%; height:25px;"></textarea>
        <input type="submit" name="submit" value="submit" id="submitbtn" />
        <input type="hidden" name="onid" value="2" id="submitbtn"/>
        </form>
                    </td>
                </tr>
            </table>

    <?php } ?>
</div>
</body>
</html>
4

2 回答 2

0

我认为你应该使用

$("form#formA").submit(function(){
  alert(1);
});
于 2013-07-23T17:07:58.137 回答
0

alert(...)无论if. _ 之后立即执行if

请注意,ajax不会重定向代码的“流”。浏览器只会“启动” AJAX 请求并继续。然后,在收到服务器的响应后 - 将执行 AJAX 回调函数。

更新:

要将表单“传递”到submitformbyajax函数 addthis作为参数:

<form name="formA" id="formA" onsubmit="submitformbyajax(this);">

JS:

function submitformbyajax(your_form) {
    var currentForm = $(your_form);
于 2013-07-23T17:10:15.737 回答