栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

创建一个“ Ajaxified”表单字段类型

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

创建一个“ Ajaxified”表单字段类型

我写了一个包(Alsatian /
FormBundle
),它可以在服务器端实现您想要的功能。

  • 如何避免通过每个表单渲染加载每个实体:
        abstract class AbstractExtensibleChoicesType extends AbstractRoutableType    {        public function configureOptions(OptionsResolver $resolver)        {   $resolver->setDefault('choices',array());        }    }
  • 如何使用缓存的内容填充表单字段:

我建议,这是您自己的逻辑:创建一个仅返回(作为HTML)的控制器:

<option value="1">Option 1</option><option value="2">Option 2</option>

在控制器中设置Maxage:

        public function getOptionsAction(Request $request) // Home    {        $choices = $this->getDoctrine()->getManager()->getRepository //....        return $this->render();    }

使用javascript加载此URL,并将html结果放入您的选择字段。

如果您使用的是Select2之类的东西:您的控制器还可以将选项作为JSONReponse()返回,那么您可以直接从select2
ajax选项加载此JSON(请参阅包文档,这就是我的用法)。

  • 最困难的是:如何使提交的选择有效:

在Form :: PRE_SUBMIT事件中获取汇总的选择(如果使用表单进行编辑,则也请获取PRE_SET_DATA),然后将这些选择重新注入到字段中。



转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/413498.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号