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 代码
});
相关推荐
陈随易4 小时前
有生之年系列,Nodejs进程管理pm2 v7.0发布
前端·后端·程序员
冰暮流星4 小时前
javascript之事件代理/事件委托
前端
陈随易5 小时前
AI时代,你还在坚持手搓文章吗
前端·后端·程序员
里欧跑得慢7 小时前
17. Flutter Hero动画实现:让界面过渡更加优雅
前端·css·flutter·web
IT_陈寒8 小时前
Vue的这个响应式陷阱,我debug了一整天才爬出来
前端·人工智能·后端
cn_mengbei8 小时前
用React Native开发OpenHarmony应用:Reanimated共享元素过渡
javascript·react native·react.js
kyriewen8 小时前
前端测试:别为了100%覆盖率而写测试,那是自欺欺人
前端·javascript·单元测试
去伪存真8 小时前
我自己写的第一个skills--project-core-standards
前端·agent
Data_Journal8 小时前
如何使用cURL更改User Agent
大数据·服务器·前端·javascript·数据库
掌心向暖RPA自动化9 小时前
如何获取网页某个元素在屏幕可见部分的中心坐标影刀RPA懒加载坐标定位技巧
java·javascript·自动化·rpa·影刀rpa