xandeadx.ru Блог музицирующего веб-девелопера

Drupal → Вывод простой таблицы с данными из БД

Опубликовано в

Для облегчения генерации таблиц, в Drupal есть специальная theme функция theme_table, которая на вход получает массивы с заголовками и данными, а на выходе возвращает html код таблицы.

Пример вывода таблицы со списком нод, которая содержит две колонки — номер ноды и заголовок:

Drupal 6:

$nodes = db_query("SELECT nid, title FROM {node} ORDER BY nid");
$header = array('Nid', 'Title');
$rows = array();
 
while ($node = db_fetch_object($nodes)) {
  $rows[] = array($node->nid, $node->title);
}
 
$output = theme('table', $header, $rows);

Drupal 7:

$nodes = db_select('node', 'n')->fields('n', array('nid', 'title'))->orderBy('n.nid')->execute();
$header = array('Nid', 'Title');
$rows = array();
 
foreach ($nodes as $node) {
  $rows[] = array($node->nid, $node->title);
}
 
$output = theme('table', array('header' => $header, 'rows' => $rows));

Похожая статья: Вывод html таблицы с данными из бд, сортировкой и пагинацией.

Написанное актуально для Drupal 6, Drupal 7
Похожие записи

Комментарии RSS

Как запретить сортировку, например по 'Nid', в данном случае.

убрать order by из запроса

При этом нужно оставить сортировку по 'Title'

пропишите title вместо nid

точно, тоже выход, попробовал работает сортировка только по указ. столбцам.
->orderByHeader($header[1])
тоже работает, но только по этому столбцу

А существует такой же способ для вывода массива с пагинацией?

Оставить комментарий

Содержимое этого поля является приватным и не будет отображаться публично. Если у вас есть аккаунт в Gravatar, привязанный к этому e-mail адресу, то он будет использован для отображения аватара.
  • Адреса страниц и электронной почты автоматически преобразуются в ссылки.
  • Доступные HTML теги: <a> <i> <b> <strong> <code> <ul> <ol> <li> <blockquote> <em> <s>
  • Строки и параграфы переносятся автоматически.
  • Подсветка кода осуществляется с помощью тегов: <code>, <css>, <html>, <ini>, <javascript>, <sql>, <php>. Поддерживаемые стили выделения кода: <foo>, [foo].

Подробнее о форматировании