Man*_*mal 3 python sqlalchemy flask superset flask-sqlalchemy
我是烧瓶的新手,我想将下拉列表添加到具有预定义值的表单中(不是从数据库中获取)。我创建了一个模型如下。
class DeliveryDetails(Model):
_tablename_ = 'deliverydetails'
id = Column(Integer, primary_key=True)
customer_name = Column(String(250), nullable=False)
delivery_type = Column(String(250), nullable=False)
Run Code Online (Sandbox Code Playgroud)
并查看如下。
class DeliveryDetailsView(ModelView, DeleteMixin):
datamodel = SQLAInterface(models.DeliveryDetails)
list_columns = ['customer_name','delivery_type']
search_columns = ['customer_name','delivery_type']
edit_columns = ['customer_name','delivery_type']
add_columns = edit_columns
label_columns = {
'customer_name': _("Customer Name"),
'delivery_type': _("Delivery Type") }
Run Code Online (Sandbox Code Playgroud)
我想表明Air, Land, Sea作为Delivery Types在下拉列表中。请让我知道是否可以按照我提到的做?
您可以使用WTF 表单。在您的 WTF 表单中使用以下字段:
dropdown_list = ['Air', 'Land', 'Sea'] # You can get this from your model
seqSimilarity = SelectField('Delivery Types', choices=dropdown_list, default=1)
Run Code Online (Sandbox Code Playgroud)
或者:
如果您正在使用 jinja 模板并希望在没有 WTF 形式的情况下执行此操作,那么您可以将其dropdown_list作为参数传递给render_template()。最后简单地遍历列表并在 HTML 中创建选择。
在视图文件中:
@app.route("/url_you_want")
def view_method():
dropdown_list = ['Air', 'Land', 'Sea']
return render_template('your_template.html', dropdown_list=dropdown_list)
Run Code Online (Sandbox Code Playgroud)
然后在your_template.html
<select>
{% for each in dropdown_list %}
<option value="{{each}}">{{each}}</option>
{% endfor %}
</select>
Run Code Online (Sandbox Code Playgroud)