J'essaie de créer deux boutons sur une page. Je voudrais réaliser un script différent python sur le serveur). Jusqu'à présent, je n'ai réussi à obtenir/collecter qu'un seul bouton à l'aide de
def contact():
form = ContactForm()
if request.method == 'POST':
return 'Form posted.'
Elif request.method == 'GET':
return render_template('contact.html', form=form)
Que devrais-je changer en fonction du bouton enfoncé?
Donnez à vos deux boutons le même nom et des valeurs différentes:
<input type="submit" name="submit_button" value="Do Something">
<input type="submit" name="submit_button" value="Do Something Else">
Ensuite, dans votre Flask), vous pouvez indiquer quel bouton a été utilisé pour soumettre le formulaire:
def contact():
if request.method == 'POST':
if request.form['submit_button'] == 'Do Something':
pass # do something
Elif request.form['submit_button'] == 'Do Something Else':
pass # do something else
else:
pass # unknown
Elif request.method == 'GET':
return render_template('contact.html', form=form)
La manière appropriée de faire ceci:
@app.route('/')
def index():
if form.validate_on_submit():
if 'download' in request.form:
pass # do something
Elif 'watch' in request.form:
pass # do something else
Placez les boutons watch
et download
dans votre modèle:
<input type="submit" name="download" value="Download">
<input type="submit" name="watch" value="Watch">
Dans le cas où quelqu'un était toujours à la recherche et rencontré ce SO post comme je l'ai fait.).
<input type="submit" name="open" value="Open">
<input type="submit" name="close" value="Close">
def contact():
if "open" in request.form:
pass
Elif "close" in request.form:
pass
return render_template('contact.html')
Simple, concis et ça marche. Vous n'avez même pas besoin d'instancier un objet de formulaire.
Je le gère de la manière suivante:
<html>
<body>
<form method="post" action="/">
<input type="submit" value="Encrypt" name="Encrypt"/>
<input type="submit" value="Decrypt" name="Decrypt" />
</div>
</form>
</body>
</html>
Code Python:
from flask import Flask, render_template, request
app = Flask(__name__)
@app.route("/", methods=['GET', 'POST'])
def index():
print(request.method)
if request.method == 'POST':
if request.form.get('Encrypt') == 'Encrypt':
# pass
print("Encrypted")
Elif request.form.get('Decrypt') == 'Decrypt':
# pass # do something else
print("Decrypted")
else:
# pass # unknown
return render_template("index.html")
Elif request.method == 'GET':
# return render_template("index.html")
print("No Post Back Call")
return render_template("index.html")
if __== '__main__':
app.run()
Appliquez un attribut de nom (différent) aux deux boutons, comme
<button name="one">
et les attraper dans request.data.
Je pense que cette solution est bonne:
@app.route('/contact', methods=['GET', 'POST'])
def contact():
form = ContactForm()
if form.validate_on_submit():
if form.submit.data:
pass
Elif form.submit2.data:
pass
return render_template('contact.html', form=form)
Forme:
class ContactForm(FlaskForm):
submit = SubmitField('Do this')
submit2 = SubmitField('Do that')