[英]Yii2 dropdown list : add html markups like data-food=“…” to my options
我正在使用Yii2构建应用程序。 我使用Yii2提供的Html Helper生成下拉列表:
<?= Html::dropDownList('food', $food_id, $foodList, ['id'=>'food-select']); ?>
其中$ food_id是默认选择的选项,$ foodList是一个包含表示选项值和文本的键值对的数组。
它工作得很好,但我需要在我的选项中添加一个html-markup(data-food =“...”)。 像这样的东西:
<select id='food-select'>
<option id="1" data-food="apple-info">Apple</option>
</select>
这可能使用Html :: dropDownList()方法吗? 无论如何要做到这一点?
您可以使用$options
数组的options
参数,如下所示:
$food_list = [1 => 'Apple', 2 => 'Banana', 4 => 'Orange']; //let's assume
<?= Html::dropDownList('food', $food_id, $food_list, [
'id'=>'food-select',
'options' => [
1 => ['data-food'=>'apple-info'], //index must be same as the option value
2 => ['data-food'=>'banana-info'],
4 => ['data-food'=>'orange-info']
]
]);
?>
下拉列表后的输出 -
<select id="food-select" name="food">
<option value="1" data-food="apple-info">Apple</option>
<option value="2" data-food="banana-info">Banana</option>
<option value="4" data-food="orange-info">Orange</option>
</select>
来自文档 - http://www.yiiframework.com/doc-2.0/yii-helpers-basehtml.html#dropDownList()-detail
options:array,select选项标签的属性。 数组键必须是有效的选项值,数组值是相应选项标记的额外属性。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.