web-dev-qa-db-fra.com

Flask Python

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é?

46
dojogeorge

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)
94
Miguel

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">
23
Alexander.Iljushkin

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.

8
poply

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()
4
user3427630

Appliquez un attribut de nom (différent) aux deux boutons, comme

<button name="one">

et les attraper dans request.data.

2

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')
1
slinden