dpw43061 2017-05-17 13:22
浏览 40
已采纳

Symfony复选框列出了枝条渲染

I'm quite new to Symfony and I have a specific question. I have a form for a job application where the applicant can choose competencies linked to categories.

Entities:

Application linked to Competence as many to many

Compentence linked to Category as Many to One

So in ApplicationType I have:

->add('competences', EntityType::class, array(
    'class'        => 'SanOffresBundle:Competence',
    'label' => 'Compétences (sélectionnez-en autant que vous voulez)',
    'choice_label' => 'nom',
    'multiple'     => true,
    'expanded' => true,
    'query_builder' => function (CompetenceRepository $er) {
        return $er->createQueryBuilder('cc')
        ->orderBy('cc.nom', 'ASC');},
    'group_by' => function($val, $key, $index) {
        return $val->getCategorie()->getNom();},        
    ))

With this code and variations I get:

  • 'expanded' => false : a menu with competences sorted by category, but the categories are not in alphabetical order. This would be an acceptable alternative if the categories were sorted, but with more than 100 competences to choose from, it's not user friendly.

  • 'expanded' => true : a list of competences checkboxes displayed grouped by categories, but the categories are not shown.

Would anybody have an idea?

  • 写回答

1条回答 默认 最新

  • dtnd30892 2017-05-17 14:38
    关注

    If you'd like to change order in secect with all Competence than you probably should extend your query builder with join

    'query_builder' => function (CompetenceRepository $er) {
            return $er->createQueryBuilder('cc')
                   ->join('cc.category', 'cat') //something like that
                   ->orderBy('cat.name', 'ASC')->addOrderBy('cc.nom', 'ASC');
    }
    

    another way would be to try @ORM\OrderBy({...}) Annotation in your relations between Compentence and Category. See link

    'expanded' => true : a list of competences checkboxes displayed grouped by categories, but the categories are not shown.

    Which is correct since it's inherited option from ChoiceType. Group by works only if you render it as a <SELECT> dropdown where you can make use of <optgroup> for grouping. I think there's no way to get a bunch (list) of checkboxes with any grouping from symfony's FormTypes out of the box..at least without any extra offer.

    Of cource you can create your own FormType and extend Twig-Widgets an so on. ...Or you could try to get desired look with Collection of (embedet) Forms ...but that are just thoughts since I do not know how your entities and their relations look like.

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥15 preLaunchTask"C/C++: aarch64- apple-darwin22-g++-14 生成活动 文件”已终止,退出代码为-1。
  • ¥18 关于#贝叶斯概率#的问题:这篇文章中利用em算法求出了对数似然值作为概率表参数,然后进行概率表计算,这个概率表是怎样计算的呀
  • ¥20 C#上传XML格式数据
  • ¥15 elementui上传结合oss接口断点续传,现在只差停止上传和继续上传,各大精英看下
  • ¥100 单片机hardfaulr
  • ¥20 手机截图相片分辨率降低一半
  • ¥50 求一段sql语句,遇到小难题了,可以50米解决
  • ¥15 速求,对多种商品的购买力优化问题(用遗传算法、枚举法、粒子群算法、模拟退火算法等方法求解)
  • ¥100 速求!商品购买力最优化问题(用遗传算法求解,给出python代码)
  • ¥15 虚拟机检测,可以是封装好的DLL,可付费