消息闪烁(Message Flashing)
优质
小牛编辑
134浏览
2023-12-01
一个好的基于GUI的应用程序向用户提供有关交互的反馈。 例如,桌面应用程序使用对话框或消息框,JavaScript使用警报用于类似目的。
在Flask Web应用程序中生成这样的信息性消息很容易。 Flask框架的闪烁系统可以在一个视图中创建消息,并在名为next的视图函数中呈现它。
Flask模块包含flash()方法。 它将消息传递给下一个请求,该请求通常是一个模板。
flash(message, category)
这里,
message参数是要刷新的实际消息。
category参数是可选的。 它可以是'错误','信息'或'警告'。
为了从会话中删除消息,模板调用get_flashed_messages() 。
get_flashed_messages(with_categories, category_filter)
两个参数都是可选的。 如果接收的消息具有类别,则第一个参数是元组。 第二个参数仅用于显示特定消息。
以下闪烁在模板中收到消息。
{% with messages = get_flashed_messages() %}
{% if messages %}
{% for message in messages %}
{{ message }}
{% endfor %}
{% endif %}
{% endwith %}
现在让我们看一个简单的例子,演示Flask中的闪烁机制。 在以下代码中, '/' URL显示登录页面的链接,没有消息要闪存。
@app.route('/')
def index():
return render_template('index.html')
该链接将用户引导至'/login' URL,该URL显示登录表单。 提交后, login()视图函数会验证用户名和密码,并相应地闪烁'success'消息或创建'error'变量。
@app.route('/login', methods = ['GET', 'POST'])
def login():
error = None
if request.method == 'POST':
if request.form['username'] != 'admin' or \
request.form['password'] != 'admin':
error = 'Invalid username or password. Please try again!'
else:
flash('You were successfully logged in')
return redirect(url_for('index'))
return render_template('login.html', error = error)
如果出现error ,将重新显示登录模板并显示错误消息。
Login.html
<!doctype html>
<html>
<body>
<h1>Login</h1>
{% if error %}
<p><strong>Error:</strong> {{ error }}
{% endif %}
<form action = "" method = post>
<dl>
<dt>Username:</dt>
<dd>
<input type = text name = username
value = "{{request.form.username }}">
</dd>
<dt>Password:</dt>
<dd><input type = password name = password></dd>
</dl>
<p><input type = submit value = Login></p>
</form>
</body>
</html>
另一方面,如果login成功,则会在索引模板上刷新成功消息。
Index.html
<!doctype html>
<html>
<head>
<title>Flask Message flashing</title>
</head>
<body>
{% with messages = get_flashed_messages() %}
{% if messages %}
<ul>
{% for message in messages %}
<li<{{ message }}</li>
{% endfor %}
</ul>
{% endif %}
{% endwith %}
<h1>Flask Message Flashing Example</h1>
<p>Do you want to <a href = "{{ url_for('login') }}">
<b>log in?</b></a></p>
</body>
</html>
Flask消息闪烁示例的完整代码如下 -
Flash.py
from flask import Flask, flash, redirect, render_template, request, url_for
app = Flask(__name__)
app.secret_key = 'random string'
@app.route('/')
def index():
return render_template('index.html')
@app.route('/login', methods = ['GET', 'POST'])
def login():
error = None
if request.method == 'POST':
if request.form['username'] != 'admin' or \
request.form['password'] != 'admin':
error = 'Invalid username or password. Please try again!'
else:
flash('You were successfully logged in')
return redirect(url_for('index'))
return render_template('login.html', error = error)
if __name__ == "__main__":
app.run(debug = True)
执行上述代码后,您将看到如下所示的屏幕。
![Flask消息闪烁示例](https://imgs.xnip.cn/cj/docimg/358/6ac35eda-13f1-428b-97b9-c22812a9f2a2.jpg)
单击该链接后,您将进入“登录”页面。
输入用户名和密码。
![登录页面](https://imgs.xnip.cn/cj/docimg/358/37cac9f2-5887-4113-b5b9-ee597cbfdae0.jpg)
单击Login 。 将显示一条消息“您已成功登录”。
![成功登录页面](https://imgs.xnip.cn/cj/docimg/358/0ac3eacd-17a1-48e3-b4c9-cf9a331bfec6.jpg)