Drupal Форма в табличной макете
-
10-10-2019 - |
Вопрос
Я пытаюсь сделать табличную планировку (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="">
Какова проблема, что атрибуты имени и стоимости не применяются на флажок?
Решение
Имя и значение - это не то, что вы можете установить с помощью атрибутов, при использовании 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;
Делать что-то вроде этого, вы можете создать таблицу в функции темы для формы. Оказание элементов формы в функции темы, даст им правильное имя.