首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >具有远程数据源的Deform2多选择

具有远程数据源的Deform2多选择
EN

Stack Overflow用户
提问于 2017-01-12 01:42:02
回答 1查看 92关注 0票数 1

我希望有一个表单,其字段类型为multiselect,使用deform (如本例中的多重/),但有来自远程数据源的选择(json调用)。

实现它的最佳方法是什么?使用deform2是可能的,还是应该回到jquery等方面。

谢谢!

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2017-01-13 05:58:01

在服务器端填充选择值肯定更容易,您可以使用冒号延迟来为选择字段设置values

代码语言:javascript
复制
@colander.deferred
def deferred_choices_widget(node, kw):
    choices = kw.get('choices')
    return deform.widget.SelectWidget(values=choices)


@colander.deferred
def deferred_default(node, kw):
    return kw['default']


class Schema(colander.Schema):
    pepper = colander.SchemaNode(
        colander.String(),
        default=deferred_default,
        widget=deferred_choices_widget,
        )

def view(request):            

    # choices = (
    #    ('', '- Select -'),
    #    ('habanero', 'Habanero'),
    #    ('jalapeno', 'Jalapeno'),
    #    ('chipotle', 'Chipotle')
    #    )

    choices = load_data_from_some_api()

    schema = Schema().bind(choices=choices, default='jalapeno')
    form = deform.Form(schema, buttons=('submit',))

    return self.render_form(form)

然而,为了使它更快,您可能希望有某种缓存。通常一个好的模式是

  • 有一个预定的任务(芹菜)从API中获取值,例如每60分钟一次,并将它们存储在数据库中。
  • 视图代码不会执行任何时间昂贵的API调用,但总是直接从数据库填充值。

变形实例

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/41603785

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档