Flask+Ajax动态加载案例(一)与INPUT控件的交互

本系列将介绍Flask+Ajax动态加载案例,这次先介绍与INPUT控件的交互。

涉及到前后台的代码,整体逻辑如下:
前台:使用jquery+ajax+input控件,通过获取input的控件的内容然后ajax异步加载方式传送到后台代码处理。
后台:接收前台传送过来的数据,并按照业务逻辑处理,处理完毕后,将数据打包封装成json格式的数据。
前台:将后台传送过来的json格式的数据,解码然后分别赋值给结果的input控件显示。

直接上代码:

一、整体目录结构

在这里插入图片描述

二、HTML文件(index.html)

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <title>Flask+Ajax动态加载案例(一)</title>
    <script src="http://apps.bdimg.com/libs/jquery/2.1.4/jquery.js"></script>
</head>

<body>
    <p>&nbsp;&nbsp;数据展示:&nbsp;&nbsp;
        <input type="text" id ="NAME" name="NAME">
        <input type="text" id ="AGE">
        <button id = "btn">点击获取</button>
    </p>
    <p>结果显示区:
        <input type="text" id ="NAME2">
        <input type="text" id ="AGE2">
    </p>

    <script>
        $(function() {
            $("#btn").click(function(){
                $.ajax({
                url: "ajax_post",
                type: "POST",
                dataType: "json",
                data : {NAME:$("input[name='NAME']").val(),AGE:$("input[id='AGE']").val()},
                success: function (data) {
	                $("#NAME2").val(data.name);
                    $("#AGE2").val(data.age);
                    console.log(data)}
                })
            })
        })
    </script>
</body>
</html>

三、后台代码文件(app.py)

from flask import Flask, render_template,request
import json

app = Flask(__name__)

@app.route('/ajax_post', methods=['GET', 'POST'])  # 路由
def ajax_post():
    testInfo['name'] = request.values.get('NAME')
    testInfo['age'] = request.values.get('AGE')
    print(testInfo)
    return json.dumps(testInfo)

@app.route('/')
def hello_world():
    return 'Hello World!'

@app.route('/index')
def index():
    return render_template('index.html')

if __name__ == "__main__":
    app.run(debug=True)

四、运行效果

在这里插入图片描述
OK,整个案例介绍完毕,这是一个相对简单的案例,作为入门的案例,非常实用,可以让我们理解前后台数据的交互动作、ajax的异步处理机制、json打包等内容。

  • 4
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
好的,我给你提供一份简单的示例代码,你可以根据自己的需要进行修改。首先是 HTML 文件: ```html <!DOCTYPE html> <html> <head> <title>Login</title> <script src="https://cdn.bootcdn.net/ajax/libs/jquery/3.6.0/jquery.min.js"></script> </head> <body> <h1>Login</h1> <form> <label for="username">Username:</label> <input type="text" id="username" name="username"><br><br> <label for="password">Password:</label> <input type="password" id="password" name="password"><br><br> <input type="button" id="submit" value="Submit"> </form> <script> $(document).ready(function() { $("#submit").click(function() { var username = $("#username").val(); var password = $("#password").val(); $.ajax({ url: "/login", type: "POST", data: { username: username, password: password }, success: function(response) { if (response == "success") { window.location.href = "/dashboard"; } else { alert("Invalid username or password."); } }, error: function() { alert("Error occurred."); } }); }); }); </script> </body> </html> ``` 这个 HTML 文件包含了一个表单,用户输入用户名和密码,点击 Submit 按钮后会触发一个 AJAX 请求,将用户名和密码发送到后端进行验证。 接下来是 Flask 后端的代码: ```python from flask import Flask, render_template, request, session, redirect, url_for app = Flask(__name__) app.secret_key = "your_secret_key" @app.route("/") def index(): return render_template("login.html") @app.route("/login", methods=["POST"]) def login(): username = request.form["username"] password = request.form["password"] # 在这里进行用户名和密码的验证,可以连接数据库或者使用其他方式进行验证 if username == "admin" and password == "123456": session["username"] = username return "success" else: return "failure" @app.route("/dashboard") def dashboard(): if "username" in session: return "Welcome, " + session["username"] + "!" else: return redirect(url_for("index")) @app.route("/logout") def logout(): session.pop("username", None) return redirect(url_for("index")) if __name__ == "__main__": app.run(debug=True) ``` 这个 Flask 应用包含了三个路由: - `/`:渲染登录页面的路由。 - `/login`:接收 AJAX 请求的路由,进行用户名和密码的验证。 - `/dashboard`:展示用户登录后的页面。 在这个示例中,我们使用 Flask 的 session 来保存用户的登录状态。如果用户成功登录,我们将用户的用户名保存在 session 中,然后跳转到 `/dashboard` 路由,展示欢迎页面。如果用户访问 `/dashboard` 路由但是没有登录,我们将会重定向到登录页面。如果用户访问 `/logout` 路由,我们将会清除 session 中的用户名,然后重定向到登录页面。 注意,在实际应用中,我们需要使用更安全的方式进行密码验证,例如使用哈希加盐算法等。此外,在这个示例中,我们使用了简单的页面重定向和 alert 弹框来展示消息,但是在实际应用中,我们可能需要使用更好的用户体验方式来展示消息,例如使用 toastr 或者使用 Bootstrap 的模态框。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值