2017-12-03 3 views
0

Der Code ist ziemlich selbsterklärend - Ich möchte eine Variable an eine FlaskForm Unterklasse zur weiteren Verwendung übergeben.Übergeben und verwenden Sie eine Variable in einem FlaskForm (WTForms)

from flask import Flask, render_template_string 
from flask_wtf import FlaskForm 
from wtforms import StringField 
from flask_wtf.csrf import CSRFProtect 


app = Flask(__name__) 
spam = 'bar' 
app.secret_key = 'secret' 
csrf = CSRFProtect(app) 

@app.route('/') 
def index(): 
    eggs = spam 
    form = FooForm(eggs) 
    return render_template_string(
    ''' 
    {{ form.bar_field.label }} {{ form.bar_field }} 
    ''',form = form) 

class FooForm(FlaskForm): 
    def __init__(self, bar): 
     super(FooForm, self).__init__() 
     self.bar = bar 
    bar_field = StringField("Label's last word is 'bar': {0}".format(self.bar)) 

if __name__ == '__main__': 
    app.run(debug=True) 

Was ich stattdessen

ist
line 22, in FooForm 
    bar_field = StringField("Label's last word is 'bar': {0}".format(self.bar)) 
NameError: name 'self' is not defined 

Wie kann ich die gewünschte erreichen?

Antwort

0

setzen Sie Ihre bar_field = StringField("Label's last word is 'bar': {0}".format(self.bar)) innerhalb init() Methode. verwenden Sie dies:

class FooForm(FlaskForm): 
def __init__(self, bar): 
    super(FooForm, self).__init__() 
    self.bar = bar 
    self.bar_field = StringField("Label's last word is 'bar': {0}".format(self.bar)) 
+0

Dies ist nicht das, was ich erreichen möchte. Ich will kein bar_field für FlaskForm, ich will bar_field für mein FooForm. – user8491711

+0

Haben Sie Ihren Vorschlag sogar selbst ausprobiert? Es gibt 'jinja2.exceptions.UndefinedError: '__main __. FooForm-Objekt' hat kein Attribut 'bar_field' ' – user8491711

+0

dann setzen 'self.bar_field = StringField ....' –

Verwandte Themen