0

我正在尝试将jscolor添加到输入字段,但它不适用于我!

在配置功能中:

public function configure() {
        unset($this['created_at'],$this['clicks']);
        $this->widgetSchema['background_color']->sfWidgetFormInput('class'=> 'jscolor');
} 

我还尝试在BaseForm中添加以下内容:

$this->setWidgets(array(
            'id'            => new sfWidgetFormInputHidden(),
            'background_color'  => new sfWidgetFormInput(array('class'=> 'jscolor')),
            'url_link'      => new sfWidgetFormInput(),
            'status'        => new sfWidgetFormInput(),
        ));

错误:sfWidgetFormInput 函数中不允许使用类!

我想添加一个类jscolor!如何通过 JavaScript 或使用此配置添加它?

4

2 回答 2

2

一个sfWidgetFormInput(实际上,任何 symfony1 小部件)需要 2 个参数 -$options$attributes. 您将类作为选项而不是作为属性传递。在模板中调用时添加类属性render()是一种选择,但我可能会选择(在大多数情况下)在配置方法中设置表单时这样做

public function configure() {
        unset($this['created_at'], $this['clicks']);

        $this->setWidget('background_color', new sfWidgetFormInput(array(), array('class'=> 'jscolor'));

        // or to be a bit more minimalistic:
        $this->getWidget('background_color')->setAttribute('class','jscolor');
}

baseForm 可能是自动生成的,我强烈建议不要修改它。

于 2018-01-02T03:49:46.217 回答
1

在将模板中的表单元素呈现为:

<?php echo $form['background_color']->render(array('class' => 'jscolor')); ?>
于 2018-01-01T11:30:53.657 回答