首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >如何基于ajax响应提交表单和停止提交表单

如何基于ajax响应提交表单和停止提交表单
EN

Stack Overflow用户
提问于 2017-04-07 20:44:31
回答 3查看 903关注 0票数 1

我正在使用带有onsubmit标签的表单。在onsubmit函数中,我将调用ajax,并在成功函数中返回true,在错误部分中返回false。但是表格总是被提交的。

html

代码语言:javascript
运行
复制
<form action="/" method="post" onsubmit="return formsubmit()">

脚本

代码语言:javascript
运行
复制
function formsubmit() {
"use strict";
var isBasic = $(".test").val() //this is hidden element
if (isBasic === "true") {      
    return true;
}
if (isBasic === "false") {      
        $.ajax({
            type: "post",
            url: "/",
            data: "sample",
            success: function (data) {
                if (data.success) {
                    return true;
                }
                if (!data.success) {                      
                    return false;
                }
            },
            error: function () {

            }
        });
    }
}

}

这对我不起作用。始终提交表单。请帮我解决这个问题。

EN

回答 3

Stack Overflow用户

发布于 2017-04-07 20:55:56

您希望从"formsubmit“函数返回一个值是正确的,但是您不能从异步调用返回( ajax调用是异步调用)。

重构您的代码以捕获按钮单击,而不是响应表单提交。在按钮单击事件中,执行ajax调用,将一个回调函数传递给ajax调用。在回调函数中,决定是否提交表单。

票数 2
EN

Stack Overflow用户

发布于 2017-04-07 21:09:17

像这样修改你的代码。

代码语言:javascript
运行
复制
function formsubmit() {
 "use strict";
 var isBasic = $(".test").val(); //this is hidden element

  if (isBasic === "false") {      
      $.ajax({
         type: "post",
         url: "/",
         data: "sample",
         success: function (data) {
            if (data.success) {
                return true;
            }
            if (!data.success) {                      
                return false;
            }
        },
        error: function () {

        }
    });
}else{
  return true;
}
 return false;
}
}
票数 0
EN

Stack Overflow用户

发布于 2017-04-07 21:12:40

代码语言:javascript
运行
复制
function formsubmit() {
    "use strict";
    var isBasic = $(".test").val() //this is hidden element
    if (isBasic === "true") {      
        return true;
    }
    if (isBasic === "false" && !$(this).attr('submit-suggest')) {      
            $.ajax({
                type: "post",
                url: "/",
                data: "sample",
                success: function (data) {
                    if (data.success) {
                        $(this).attr('submit-suggest',1);
                        $(this).submit();
                    }
                    if (!data.success) {                      
                        $(this).attr('submit-suggest',0);
                    }
                },
                error: function () {
                    $(this).attr('submit-suggest',0);
                }
            });
        return false;
    }
    return true;
}
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/43278512

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档