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 代码
});
相关推荐
陈随易1 小时前
编程语言级别的Skill市场,AI Agent 的未来形态
前端·后端·程序员
SoaringHeart2 小时前
Flutter进阶:基于 EasyRefresh 的下拉刷新封装 n_easy_refresh_mixin.dart
前端·flutter
IT_陈寒4 小时前
Vite的热更新突然不香了,排查三小时差点砸键盘
前端·人工智能·后端
子兮曰4 小时前
Agency-Agents 深度解析:400+ AI 专家的"梦之队"如何重塑开发工作流
前端·后端·vibecoding
山河木马5 小时前
渲染管线-计算得到gl_Position(顶点着色器)之后续GPU流程
javascript·webgl·图形学
竹林8185 小时前
用 The Graph 查询链上数据实战:从手搓 RPC 到 Subgraph,我的 NFT 项目数据加载快了 10 倍
前端·javascript
妙码生花5 小时前
从 PHP 到 AI + Golang,程序员自救转型手记(十九):点选验证码代码逐行目检
前端·后端·go
Awu12276 小时前
⚡从零开发 Agent CLI(五)实现一个可治理、可扩展的工具系统
前端·人工智能·claude
咪库咪库咪6 小时前
Vue3-生命周期
前端
莪_幻尘7 小时前
你的 AI Skill 越多越蠢?Token 上下文爆炸的求生指南
前端·ai编程