首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >EasyAdmin3:编辑表单上的两列概念(引导)

EasyAdmin3:编辑表单上的两列概念(引导)
EN

Stack Overflow用户
提问于 2020-12-01 05:29:43
回答 1查看 169关注 0票数 2

背景

我正在使用EasyAdmin3 (Symfony 5),我希望在编辑视图中有一个两列的概念。下面的代码正确地将块的宽度“缩小”到50%,但它们不是相邻的。

代码语言:javascript
复制
class PersonCrudController extends AbstractCrudController {
    [...]

    public function configureFields(string $pageName): iterable {

        yield FormField::addPanel('Block 1')->setCssClass('col-sm-6');
        [...]

        yield FormField::addPanel('Block 2')->setCssClass('col-sm-6');
        [...]
    }

    [...]
}

问题

我想问一下,我需要用一个包含class="row"的DIV元素包围它。但是怎么做呢?

知道吗,我能做什么?谢谢!

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2020-12-01 06:40:03

我的解决方案

我决定用JavaScript来解决这个问题。因此,我检查了HTML表单的名称,并使用JavaScript将row-class注入到该元素。JavaScript文件需要通过来填充(将来可以对其他元素进行重用)。

my_javascript.js

代码语言:javascript
复制
// call functions once page is loaded
document.addEventListener("DOMContentLoaded", function() {
    addClassToElement('edit-Person-form', 'row');
});

function addClassToElement(elementName, className) {
    let element = document.getElementById(elementName);

    if (element != null) {
        element.classList.add(className);
    }
}

dashboard-controller

代码语言:javascript
复制
[...]
public function configureAssets(): Assets {
    $assets = parent::configureAssets();

    $assets->addJsFile('js/my_javascript.js');

    return $assets;
}
[...]

PersonCrudController

代码语言:javascript
复制
class PersonCrudController extends AbstractCrudController {
    [...]

    public function configureFields(string $pageName): iterable {

        yield FormField::addPanel('Block 1')->setCssClass('col-sm-6');
        [...]

        yield FormField::addPanel('Block 2')->setCssClass('col-sm-6');
        [...]
    }

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

https://stackoverflow.com/questions/65085207

复制
相关文章

相似问题

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