0

最初のセルにチェックボックスが含まれるようなフォームの表形式のレイアウト(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="">

名前と値の属性がチェックボックスに適用されない問題は何ですか?

4

1 に答える 1

2

名前と値は、フォームAPIを使用するときに属性を使用して設定できるものではありません。名前はフォームアイテムのキーに関連しているので、

$form['pony'] = $checkbox;
$form['yes'] = $checkbox;

最初のチェックボックスにはの名前が付けられpony、2番目のチェックボックスにはの名前が付けられ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;

このようなことを行うと、フォームのテーマ関数でテーブルを作成できます。テーマ関数でフォーム要素をレンダリングすると、正しい名前が付けられます。

于 2010-10-21T08:03:51.357 に答える