1

我在 SilverStripe 4 中创建自定义 CMS 字段,它们是用左列中的标签和右列中的编辑器构建的。

见图片: 在此处输入图像描述

如何像图片中看到的默认内容编辑器和标签一样堆叠标签和编辑器?

4

1 回答 1

1

所以我在寻找其他东西时终于找到了答案。我会回答我自己的问题,以防有人在未来寻找同样的东西,因为寻找 Silverstripe 问题的答案很困难。

在文档中,它说要为额外的所见即所得编辑器执行此操作

return new FieldList([
    new HTMLEditorField('OtherContent', 'Other content', $this->OtherContent, 'myConfig')
]);

我们将把它分解成组件来给我们更多的控制权

$fields = parent::getCMSFields();
//create a $fields variable that will hold the new fields

$jobDescriptionField = HTMLEditorField::create('JobDescription', 'JobDescription');
//create the actual field in it's own variable

$fields->addFieldToTab('Root.Main', $jobDescriptionField , 'Content');
//add the new field to our fields and tell it to appear above the default 'Content' editor

如果我们停在这里并返回 $fields,我们将让标签浮动到左边,内容编辑器浮动到右边。即使在全屏上它也会被压扁。不好。

所以我们需要添加一个由 silverstripe 提供的名为“stacked”的类

$jobDescriptionField->addExtraClass('stacked');

所以完整的代码如下:

public function getCMSFields(){
    $fields = parent::getCMSFields();

    $jobDescriptionField = HTMLEditorField::create('JobDescription', 'JobDescription');

    $fields->addFieldToTab('Root.Main', $jobDescriptionField , 'Content');

    $jobDescriptionField->addExtraClass('stacked');
    return $fields;

}
于 2017-12-28T20:57:23.970 回答