如何在烧瓶应用程序模型中添加带有值(预定义)的下拉列表?

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在下拉列表中。请让我知道是否可以按照我提到的做?

Nab*_*bin 5

您可以使用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)