In Drupal 8, il rendering delle tabelle è ancora molto simile a Drupal 7. Costruisci array multidimensionali di righe e colonne in PHP che Drupal trasforma rispettivamente in a <tr>
e <td>
s. C'è ancora questo confuso drupalismo noto come 'data'
che consente di aggiungere elementi dell'array di rendering come dati di cella (da non confondere con gli attributi di dati).
Mi è stato assegnato un sito in cui lo sviluppatore ha scelto di utilizzare i "dati" per eseguire il rendering dei contenuti della cella, ma non riesco a capire come aggiungere una classe ai <td>
dati circostanti.
Ho letto il codice sorgente e la documentazione per Table.php e sono a conoscenza del nuovo #wrapper_attributes
ma non riesco a decifrarlo .
Ho provato almeno quattro modi per aggiungere la classe e nessuno funziona.
$table['row-' . $row_id] = [
// Option 1: Class appears on <tr> tag
'#attributes' => [
'class' => ['option-1-row-attributes'],
'id' => 'row-' . $row_id,
'no_striping' => TRUE,
],
// Option 2: Class appears on <td> tag of first column.
'item' => [
'#markup' => $row['my_item']->label(),
'#wrapper_attributes' => [
'class' => ['option-2-markup-wrapper-attributes'],
],
],
// In the following section, the only item that works is
// the class on the <a> tag.
'edit_operation' => [
'data' => [
'#type' => 'link',
'#url' => Url::fromRoute('my_module.my_route', ['item' => $row_id]),
'#title' => $this->t('Edit'),
'#attributes' => [
// Option 3: Class appears on the anchor tag
'class' => ['use-ajax', 'option-3-link-attributes'],
'data-dialog-type' => 'modal',
'data-dialog-options' => Json::encode([
'width' => 700,
]),
],
// Option 4: Has no effect.
'#wrapper_attributes' => [
'class' => ['option-4-data-wrapper-attributes'],
],
],
// Option 5: Update: This appears to be the correct solution!
// Class appears on the <td>.
'#wrapper_attributes' => [
'class' => ['option-5-wrapper-attributes'],
],
// Option 6: Has no effect.
'#attributes' => [
'class' => ['option-6-attributes'],
],
// Option 7: Has no effect.
'class' => ['option-7-attributes'],
],
];