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 代码
});
相关推荐
r0ad3 分钟前
从痛点到解决方案:为什么我开发了Chrome元素截图插件
前端·chrome
OEC小胖胖10 分钟前
连接世界:网络请求 `wx.request`
前端·微信小程序·小程序·微信开放平台
jingling55523 分钟前
解决微信小程序真机调试中访问本地接口 localhost:8080 报错
前端·微信小程序·小程序
en-route24 分钟前
使用 Flask 构建 Web 应用:静态页面与动态 API 访问
前端·python·flask
IT_陈寒26 分钟前
Vite 5年迭代揭秘:3个核心优化让你的项目构建速度提升200%
前端·人工智能·后端
怎么吃不饱捏41 分钟前
vue3+vite,引入阿里巴巴svg图标,自定义大小颜色
前端·javascript·vue.js
无敌最俊朗@43 分钟前
MQTT 关键特性详解
java·前端·物联网
JAVA学习通43 分钟前
微服务项目->在线oj系统(Java-Spring)----[前端]
java·开发语言·前端
excel1 小时前
Vue3 响应式系统核心执行器:Reactive Effect 与依赖调度机制
前端
南玖i3 小时前
vue3 通过 Vue3DraggableResizable实现拖拽弹窗,可修改大小
前端·javascript·vue.js