【问题标题】:Using dgrid in form collections in a Zend Framework 2 application在 Zend Framework 2 应用程序的表单集合中使用 dgrid
【发布时间】:2012-09-15 02:57:59
【问题描述】:

对于我们的新项目,我们已经开始使用 Zend Framework 2 和 Dojo 1.8。 ZF2 有一个完全重写的表单模块,它现在具有用于一对多关系的新 CollectionElement。关于 UI,我发现 dgrid 最适合这种关系(使用编辑器列插件),所以我开始扩展 FormCollection、FormRow 和 FormElement 视图助手,以便它们可以呈现所需的 dgrid。一切都很好,直到我意识到我无法为 dgrid 小部件设置每行输入名称。

我从ZF2 documentation rearding form collections 开始。可以看到,集合输入元素具有类似数组的名称,例如

order[products][0][name]
order[products][0][price]
order[products][1][name]
order[products][1][price]

另一方面,dgrid 的配置是基于列的,所以我可以有一个类似的列定义

editor({
    field: "_dojo_textbox_505ee3a390d705_26717315", 
    label: "Name",
    editorArgs: {
        name: "order[products][{index}][name]",
    }
}, TextBox)

此列定义将为所有行定义设置相同的小部件名称,这不适用于 ZF2 集合数据格式要求。

我也尝试过这样命名列:

order[products][]

可行,但不允许使用所需的格式

order[products][][name]

也许有一种方法可以像这样发布数据:

order[products][name][]

然后将其转换,但解决方案看起来不正确。除此之外,我正在尝试生成可重用的代码并希望避免执行数据修改。

由于我非常努力地避免对数据转换进行 onSubmit/onClick 事件处理,因此有两种可能的解决方案: 1. 使 dgrid 能够设置每行小部件名称 2. 让 ZF2 表单理解一些非标准的集合 POST 格式

很遗憾,我没有办法解决这两种解决方案,如果您能帮帮我,我将不胜感激!

由于这与我当前的问题有些相关,因此我将其作为附带问题放在此处: 除了这个 UI 解决方案之外,您还为与 dojo 的一对多表单界面使用什么?

【问题讨论】:

    标签: php dojo zend-framework2 dgrid zend-form2


    【解决方案1】:

    在 Zend 框架版本 2 中,“Zend\Form”本身具有向“集合元素”动态添加新元素的能力。

    您可以查看here

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 1970-01-01
      • 2016-06-25
      • 2017-01-08
      • 1970-01-01
      • 1970-01-01
      • 2013-10-29
      • 1970-01-01
      • 2014-10-04
      相关资源
      最近更新 更多