ajax post请求 解决自动再get请求一次

ajax post请求 解决自动再get请求一次

HTML

html 复制代码
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>登录</title>
    
</head>
<body>
<div class="container">
    <div id="msg"></div>
    <form>
        <div>
            <label for="username">UserName</label>
            <input type="text" name="username" id="username">
        </div>
        <div>
            <label for="password">Password</label>
            <input type="password" name="password" id="password">
        </div>
        <div>
            <label for="check_code">Check Code</label>
            <input type="text" name="check_code" id="check_code">
        </div>
        <div>
            <button type="button" onclick="Submit()">Login</button>
            <!-- button标签一定要加type属性,禁止表单自动提交机制   -->
        </div>
    </form>
</div>
</body>
</html>

javascript

javascript 复制代码
<script>
<script src="../jquery-3.7.1.min.js"></script>
function Submit(){
    $.ajax({
        url: '/post_login',
        type: 'POST',
        contentType: 'application/json',
        dataType: 'json',
        data: $('form').serialize(),  // 发送的数据
        success: function(res) {
            if (res.code === 200){
                alert(res.msg)
            }else {
                console.log(res, '999999')
                $('#msg').text(res.msg)
            }
        },
        error: function(error) {

            console.error('Error:', error);
        }
    });

}
</script>

Flask

python 复制代码
from flask import Flask
from flask import render_template, redirect, request, jsonify
app = Flask(__name__)

@app.route('/', methods=['GET'])
@app.route('/login', methods=['GET'])
def get_login():
	# 获取登录页面
    return render_template('Login.html')

@app.route('/post_login', methods=['POST'])
def post_login():
	# 用户登录,提交表单
    return jsonify(dict(code=401, msg='success'))

第一种方法:

button按钮中,把属性type设置为type="button",防止表单默认提交机制

html 复制代码
<button type="button" onclick="Submit()">Login</button>
 <!-- button标签一定要加type属性,禁止表单自动提交机制   -->

第二种方法:

JavaScript 事件监听器未正确处理

禁止自动提交机制

javascript 复制代码
// 阻止默认的提交行为
$(document).on('click', 'button[type="submit"]', function(e) {
    e.preventDefault(); // 阻止默认的提交行为
    // 你的 AJAX 代码
    $.ajax({
        type: "POST",
        url: "/your-endpoint",
        data: { /* 数据 */ },
        success: function(response) {
            // 处理响应
        }
    });
});

// 阻止表单的默认提交行为
$('form').on('submit', function(e) {
    e.preventDefault(); // 阻止表单的默认提交行为
    // 你的 AJAX 代码
});

// 阻止事件进一步传播到其他事件处理器
$('button').on('click', function(e) {
    e.stopImmediatePropagation(); // 阻止事件进一步传播到其他事件处理器
    // 你的 AJAX 代码
});
相关推荐
涔溪35 分钟前
响应式前端设计:CSS 自适应布局与字体大小的最佳实践
前端·css
今禾35 分钟前
前端开发中的Mock技术:深入理解vite-plugin-mock
前端·react.js·vite
你这个年龄怎么睡得着的36 分钟前
Babel AST 魔法:Vite 插件如何让你的 try...catch 不再“裸奔”?
前端·javascript·vite
我想说一句39 分钟前
掘金移动端React开发实践:从布局到样式优化的完整指南
前端·react.js·前端框架
jqq66640 分钟前
Vue3脚手架实现(九、渲染typescript配置)
前端
码间舞1 小时前
Zustand 与 useSyncExternalStore:现代 React 状态管理的极简之道
前端·react.js
Dream耀1 小时前
提升React移动端开发效率:Vant组件库
前端·javascript·前端框架
冰菓Neko1 小时前
HTML 常用标签速查表
前端·html
gis收藏家1 小时前
从稀疏数据(CSV)创建非常大的 GeoTIFF(和 WMS)
前端
程序视点1 小时前
望言OCR 2025终极评测:免费版VS专业版全方位对比(含免费下载)
前端·后端·github