ОК, после более глубокого изучения документации QuickForm я понял это.Решение состоит в том, чтобы не заполнять выбранный виджет массивом, а чтобы создать элемент выбора вручную, добавьте это в форму.
Первоначально у меня было следующее:
function dbArray( $tableName, $fieldName ) {
$query = <<< EOT
SELECT `id`, `$fieldName`
FROM `$tableName`
ORDER BY `$fieldName`
EOT;
$link = connectToDatabase();
$result = mysql_query( $query, $link );
while ( $rec = mysql_fetch_assoc( $result ) );
{
$array[$rec['id']] = $rec[$fieldName];
}
return $array;
}
function statesArray() {
return dbArray( 'states', 'name' );
}
$form = new HTML_QuickForm( 'account', 'POST' );
$form->addElement( 'select', 'state_id', 'State:', statesArray() );
Я сделалверсия, где array( 'none' => 'Please select a State' )
был добавлен перед вызовом dbArray
перед возвратом массива в вызывающий код, но это не сделало опцию отключенной.В качестве обходного пути добавилось правило, подтверждающее, что выбор является числовым ($form->addRule( 'state_id', 'You must select a state.', 'numeric' )
).Но мне все еще не нравилось, что это можно было выбрать.Вот решение, которое я нашел.
function statesSelect() {
$select = HTML_QuickForm::createElement( 'select' );
$select->addOption( 'Select a State', '', array( 'disabled' => 'disabled' ) );
$select->addOption( '-', '', array( 'disabled' => 'disabled' ) );
$statesArray = dbArray( 'states', 'name' );
foreach ( $statesArray as $id => $name ) {
$select->addOption( $name, $id );
}
return $select;
}
$form = new HTML_QuickForm( 'account', 'POST' );
$form->addElement( statesSelect() );
$form->addRule( 'state_id', 'You must select a state.', 'required' );
Надеюсь, это поможет кому-то еще.:)