Drupal форма в табличной форме
Я пытаюсь сделать табличный макет (HTML-таблицу) для формы, чтобы первая ячейка содержала флажок.
$form = array();
$res = query('SELECT * FROM {mytable}');
$rows = array();
while($row = db_fetch_array($res)){
$record = array();
$checkbox = array(
'#type' => 'checkbox',
'#attributes' => array(
'value' => $row['id'],
'name' => 'myrecord[]',
),
);
$record[] = drupal_render($checkbox);
$record[] = $row['other_field_1'];
$record[] = $row['other_field_2']
$rows[] = $record;
}
$form['records'] = array(
'#value' => theme('table', array(), $rows);
);
return $form;
Но все визуализированные флажок имеет вывод
<input type="checkbox" class="form-checkbox" name="" value="1" id="">
<input type="checkbox" class="form-checkbox" name="" value="1" id="">
<input type="checkbox" class="form-checkbox" name="" value="1" id="">
<input type="checkbox" class="form-checkbox" name="" value="1" id="">
В чем проблема, когда атрибуты name и value не применяются к флажкам?
1 ответ
Имя и значение нельзя задать с помощью атрибутов при использовании API формы. Имя связано с ключом элемента формы, поэтому, если у вас было
$form['pony'] = $checkbox;
$form['yes'] = $checkbox;
Первый флажок будет иметь имя pony
в то время как второй будет иметь имя yes
, Я считаю, что значение для флажков всегда равно 1, но я не уверен на 100%.
Чтобы правильно создать эту форму, вам нужно только создать форму в определении формы. Делать что-то вроде этого:
$form = array();
$res = query('SELECT * FROM {mytable}');
while($row = db_fetch_array($res)){
$form[$row['id']] = array('#tree' => TRUE);
$form[$row['id']]['checkbox'] = array('#type' => 'checkbox');
$form[$row['id']]['other_field_1'] = array('#value' => $row['other_field_1']);
$form[$row['id']]['other_field_2'] = array('#value' => $row['other_field_1']);
}
return $form;
Делая что-то вроде этого, вы можете создать таблицу в функции темы для формы. Рендеринг элементов формы в функции темы, даст им правильное имя.