我正在尝试将角色输出到菜单列表中,我正在获取。
roles = QuerySelectField(query_factory=lambda: Role.query.filter_by(front=True), allow_blank=True)
我正在
project.models.Role object at 0x7f0205ec5cd0
获取Role->名称的正确方法是什么? 这是我的模特:
class Role(db.Model):
__tablename__ = 'roles'
id = db.Column(db.Integer, primary_key=True)
name = db.Column(db.String(20), index=True)
front = db.Column(db.Boolean, default=True)
#permissions = db.relationship('Permission', backref='permission')
users = db.relationship('User', backref='roles')
def __init__(self, name, front):
self.name = name
self.front = front
这是我的表格
class RegisterForm(Form):
email = StringField('Email', validators=[DataRequired(), Email()])
username = StringField('Username', validators=[DataRequired(), Length(min=3, max=50, message="You must enter a min and max character")])
password = PasswordField('Password', validators=[DataRequired(), EqualTo('password2', message='Your Passwords must be same')])
password2 = PasswordField('Re-Enter Password', validators=[DataRequired(), EqualTo('password', message='Passwords must match.')])
village = QuerySelectField(get_label='village', query_factory=villages_lists)
roles = QuerySelectField(query_factory=lambda: Role.query.filter_by(front=True), allow_blank=True)
答案 0 :(得分:1)
所选模型在表单字段的数据属性中可用。
e.g。收到帖子后,您可以执行以下操作:
form = RegisterForm()
if form.validate_on_submit():
print form.roles.data.name
答案 1 :(得分:1)
您需要为Role
对象提供wtforms
可以使用的字符串表示形式。
例如,在您当前的代码中,您将获得以下内容:
r = Role.query.first()
print(r) # project.models.Role object at 0x7f0205ec5cd0
如果将以下内容添加到Role类:
def __repr__(self):
return self.name
对象现在将具有该表示形式,因此如果我们再次运行相同的代码:
r = Role.query.first()
print(r) # Admin
wtforms
使用该表示来设置字段中元素的显示值,所以一旦你拥有了该集合(并返回一个有用的表示),你就会按照你期望的方式工作。