Flask+ajax实现动态更新div

需求

每秒刷新折叠面板,显示当前接入设备的个数,并创建对应的项目

效果

  • 第一次刷新前
    第一次刷新前

  • 刷新后
    刷新后

  • 随着设备列表的变化而增删

关键代码

HTML
<div id="collapsePages" class="collapse" aria-labelledby="headingPages" data-parent="#accordionSidebar">
  <div id="device_page_num" class="bg-white py-2 collapse-inner rounded">
    <h6 class="collapse-header">设备总数: 0</h6>
  </div>
</div>

要更新的就是device_page_num

Javascript
function change_div(){
    $.ajax({
        type: 'GET',
        url: '/device_card_refresh',
        timeout: 10000,
        success:function(a){
            $('#device_page_num').children().remove()
            $('#device_page_num').append($("<h6 class='collapse-header'>设备总数: "+a[0]+"</h6>"))
            for (var i in a[1]){
                var div = $("<a class='collapse-item' href=\'/devicepage/" + i + "\'>" + a[1][i] + "</a>\n")
                $('#device_page_num').append(div)
            }
        },
    })
}
setInterval(change_div, 1000)

先清空device_page_num的所有子内容,再写入新的

Flask
@app.route('/device_card_refresh')
def device_card_refresh():
    df = query.read_sql()
    device_num, device_data = getData.get_device_data(df)
    return [device_num, device_data.tolist()]

收到请求后把设备列表传给前端

  • 1
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,下面是一个简单的示例,使用 Flask 作为后台框架,Ajax 实现异步提交表单,HTML 和 Bootstrap 实现页面布局和样式。 首先,创建一个 Flask 应用,设置路由和视图函数。 ```python from flask import Flask, render_template, request, jsonify app = Flask(__name__) @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': return jsonify({'success': True}) else: return jsonify({'success': False, 'message': '用户名或密码错误'}) ``` 然后,创建一个 HTML 文件,包含登录表单和 Ajax 提交代码。 ```html <!DOCTYPE html> <html> <head> <title>后台登录</title> <meta charset="utf-8"> <meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1, user-scalable=no"> <link rel="stylesheet" href="https://cdn.bootcdn.net/ajax/libs/twitter-bootstrap/4.6.0/css/bootstrap.min.css"> </head> <body> <div class="container"> <div class="row justify-content-md-center mt-5"> <div class="col-md-6"> <h3 class="text-center mb-4">后台登录</h3> <form id="login-form"> <div class="form-group"> <label for="username">用户名</label> <input type="text" class="form-control" id="username" name="username" required> </div> <div class="form-group"> <label for="password">密码</label> <input type="password" class="form-control" id="password" name="password" required> </div> <button type="submit" class="btn btn-primary btn-block">登录</button> </form> </div> </div> </div> <script src="https://cdn.bootcdn.net/ajax/libs/jquery/3.6.0/jquery.min.js"></script> <script> $(function() { $('#login-form').submit(function(event) { event.preventDefault(); $.ajax({ url: '/login', type: 'POST', data: $(this).serialize(), dataType: 'json', success: function(data) { if (data.success) { window.location.href = '/dashboard'; } else { alert(data.message); } }, error: function() { alert('登录失败,请重试'); } }); }); }); </script> </body> </html> ``` 最后,启动应用并访问 http://localhost:5000/ 即可看到登录界面。 注意:这只是一个简单的示例,实际应用中需要做更多的安全处理,比如密码加密、防止 CSRF 攻击等。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值