Flacon - Message clignotant

Une bonne application basée sur l'interface graphique fournit des commentaires à un utilisateur sur l'interaction. Par exemple, les applications de bureau utilisent une boîte de dialogue ou une boîte de message et JavaScript utilise des alertes à des fins similaires.

La génération de tels messages informatifs est facile dans l'application Web Flask. Le système clignotant du framework Flask permet de créer un message dans une vue et de le rendre dans une fonction de vue appeléenext.

Un module Flask contient flash()méthode. Il transmet un message à la requête suivante, qui est généralement un modèle.

flash(message, category)

Ici,

  • message Le paramètre est le message réel à clignoter.

  • categoryle paramètre est facultatif. Il peut s'agir de «erreur», «info» ou «avertissement».

Afin de supprimer le message de la session, les appels de modèle get_flashed_messages().

get_flashed_messages(with_categories, category_filter)

Les deux paramètres sont facultatifs. Le premier paramètre est un tuple si les messages reçus sont de catégorie. Le deuxième paramètre est utile pour afficher uniquement des messages spécifiques.

Le suivant clignote les messages reçus dans un modèle.

{% with messages = get_flashed_messages() %}
   {% if messages %}
      {% for message in messages %}
         {{ message }}
      {% endfor %}
   {% endif %}
{% endwith %}

Voyons maintenant un exemple simple, démontrant le mécanisme de clignotement dans Flask. Dans le code suivant, un‘/’ L'URL affiche le lien vers la page de connexion, sans message à clignoter.

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

Le lien conduit un utilisateur à ‘/login’URL qui affiche un formulaire de connexion. Une fois soumis, lelogin() La fonction de visualisation vérifie un nom d'utilisateur et un mot de passe et clignote en conséquence un ‘success’ message ou crée ‘error’ variable.

@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)

En cas de error, le modèle de connexion est réaffiche avec un message d'erreur.

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>

D'autre part, si login réussit, un message de réussite est affiché sur le modèle d'index.

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>

Un code complet pour l'exemple de clignotement de message Flask est donné ci-dessous -

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)

Après avoir exécuté les codes ci-dessus, vous verrez l'écran comme indiqué ci-dessous.

Lorsque vous cliquez sur le lien, vous serez dirigé vers la page de connexion.

Entrez le nom d'utilisateur et le mot de passe.

Cliquez sur Login. Un message s'affiche «Vous avez été connecté avec succès».