javascript - 提交表单时保持表单窗口打开

标签 javascript php jquery forms fancybox

考虑这个图像,它是用户点击链接时的 iframe 窗口。

enter image description here

我的问题

当用户点击存款时,表单被提交并且窗口关闭,因此用户不知道存款是否成功。

我想做什么

我正在寻找一种方法来在提交表单后保持 iframe 窗口打开,以显示适当的消息

表单 HTML

   <form name="depForm" action="" id="register_form" method="post">
            User Name<br /><input type="text" name="uname" value="" /><br />
            Credit Card Nr<br /><input type="text" name="cc" value="" /><br />
            CSV Nr<br /><input type="text" name="csv" value="" /><br />
            Amount<br /> <input type="text" name="amount" value="" /><br />
            <input type="submit" value="deposit" name="deposit" class="buttono" />
            </form>

PHP 代码

if(isset($_POST['deposit'])){
            if(isset($_SESSION['FBID'])){
                $uid=$_SESSION['FBID'];
                $amount = $_POST['amount'];
                $cc = $_POST['cc'];
                $csv = $_POST['csv'];
                //new bal
                $bal = getBal($uid);
                $newBal = $bal+$amount;
                $sql="UPDATE members SET balance='$newBal' WHERE member_nr='$uid'";
                $result = mysql_query($sql) or die("error please try again");   
                    if($result){

                    }
            }

如果有人可以建议我如何在提交表单后保持 iframe 打开,将不胜感激。

最佳答案

您需要更改表单提交以使用 AJAX。在响应中,您可以包含一个状态标志以向 UI 指示请求是否成功并采取适当的行动。像这样:

$('#register_form').submit(function(e) {
    e.preventDefault(); // stop the standard form submission
    $.ajax({
        url: this.action,
        type: this.method,
        data: $(this).serialize(),
        success: function(data) {
            if (data.success) {
                // show success message in UI and/or hide modal
            } else {
                // it didn't work
            }
        },
        error: function(xhr, status, error) {
            // something went wrong with the server. diagnose with the above properties
        }
    });
});
$success = false;
if (isset($_POST['deposit'])) {
    if (isset($_SESSION['FBID'])) {
        $uid = $_SESSION['FBID'];
        $amount = $_POST['amount'];
        $cc = $_POST['cc'];
        $csv = $_POST['csv'];

        $bal = getBal($uid);
        $newBal = $bal + $amount;
        $sql = "UPDATE members SET balance='$newBal' WHERE member_nr='$uid'";
        $result = mysql_query($sql) or die("error please try again");   
        if ($result) {
            $success = true;
        }
    }
}

echo json_encode(array('success' => $success));

关于javascript - 提交表单时保持表单窗口打开,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31355743/

相关文章:

javascript - 字典转JSON?

php - 将 reCAPTCHA v2 添加到我的 PHP 文件中

php - html 形式 tp php 文件

javascript - 如何将 Twitter Bootstrap 与 Google map v3 结合使用?

jquery - 我怎样才能减慢这个jquery slider 的动画速度

javascript - 如果矢量图层没有特征,则不绘制 OSM 层

javascript - 仅使用按钮类调用 Javascript

javascript - three.js:按名称或 ID 访问场景对象

php - Nginx 重写基本 URL 的路径

Javascript一次选择一行