如何为使用laravel表单构建器创建的选择标记的选项指定HTML属性?

时间:2014-08-25 10:48:10

标签: php laravel formbuilder

您可以为<select>本身设置HTML属性,但<options>呢?

Form::select('name', $options, null, ['class'=>'form-control'])

1 个答案:

答案 0 :(得分:4)

第一个参数是idname属性,第二个参数是值为<select>的数组,第三个参数是选择选项,第四个参数是带有HTML属性的数组。如果您要设置nameclass或其他HTML属性,只需将其放入数组(无法使用数组设置id,必须使用第一个参数):

// View
{{ Form::select('selectname', $selectname, Input::old('selectname'), array('class'=>'form-control', 'name'=>'modified_name')) }}

EDIT1:我误解了这个问题,将HTML属性设置为<option>的唯一方法是使用Form::macro并动态构建<option>标记。


EDIT2:你应该建立这样的东西:

Form::macro('test', function($name, $list = array(), $options = array())
{
$build = array();

foreach ($list as $key => $value)
{
    $build[] = sprintf('<option id="%s" name="%s" class="%s" value="%s">%s</option>', $name, $name, $options['class'], $value->id, $value->name);
}
return join("\n", $build);
});

然后将其用于您的观点:

{{ Form::open(array('url' => 'test')) }}
    {{ Form::test('test', $list, ['class' => 'form-control']) }}
{{ Form::close() }}

结果:

<option id="test" name="test" class="form-control" value="1">Test1</option>
<option id="test" name="test" class="form-control" value="2">Test2</option>
<option id="test" name="test" class="form-control" value="3">Test3</option>

您可以将<select>标记添加到宏中,并将一些参数传递给该函数的HTML属性,或者只需将<select>标记添加到具有适当属性的视图中。