亲爱的之前已经提供过帮助的人们。
我有一个结合了自定义列和自定义数据的表。但正如您所看到的,有些数据不在右列下。
我的表代码:
<div class="card-body">
<table class="table table-hover demo-table-dynamic table-responsive-block" id="tableWithDynamicRows">
<thead>
<tr>
<?php foreach ($fieldList as $field) {
echo '<th>'.$field['name'].'</th>';
} ?>
<th>Actie</th>
</tr>
</thead>
<tbody>
<?php
foreach ($dataList as $datas) {
$values = getDataTableWithoutDatabase($datas, $list, 'datalist');
foreach ($values as $value) {
echo $value;
}
}
?>
</tbody>
</table>
</div>
我创建表的方法:
function getDataTableWithoutDatabase(array $columns, array $list, string $table) {
$i = 0;
$len = count($columns);
foreach ($columns as $key => $value) {
$field = '';
if($key == array_key_first($list)) {
$field .= '<tr>';
}
foreach ($list as $keys) {
if($key != array_key_first($list) && empty($columns[$keys]) && $key != 'uid') {
$field .= '<td class="v-align-middle"></td>';
}
}
if($key != 'uid') {
$field .= '<td class="v-align-middle">';
$field .= '<p>' . $value . '</p>';
$field .= '</td>';
}
if($key == 'uid') {
$last = '<td><a href="../'.$table.'edit?'.$table.'='. $value .'">Bewerken</a></td>';
}
if($i == $len - 1) {
$field .= $last;
$field .= '</tr>';
}
$fields[] = $field;
$i++;
}
return $fields;
}
解决办法是。我希望在正确的列下获得正确的信息:
下面是变量 $columns
$list
包含:
['Voornaam','Achternaam','Initialen']
$columns
包含:
array(4) {
["Voornaam"]=>
string(0) ""
["uid"]=>
string(15) "7d1f4f8e906245f"
["Achternaam"]=>
string(3) "Les"
["Initialen"]=>
string(0) ""
}
array(4) {
["Voornaam"]=>
string(6) "Simone"
["uid"]=>
string(15) "7d1f4f8e906245g"
["Achternaam"]=>
string(0) ""
["Initialen"]=>
string(0) ""
}
array(4) {
["Voornaam"]=>
string(0) ""
["uid"]=>
string(15) "7d1f4f8e906245l"
["Achternaam"]=>
string(4) "Yül"
["Initialen"]=>
string(0) ""
}
array(4) {
["Voornaam"]=>
string(0) ""
["uid"]=>
string(15) "7d1f4f8e906245s"
["Achternaam"]=>
string(3) "Mas"
["Initialen"]=>
string(0) ""
}
array(4) {
["Voornaam"]=>
string(0) ""
["uid"]=>
string(15) "gGcYEJdRYJ1vqcn"
["Achternaam"]=>
string(5) "Hello"
["Initialen"]=>
string(0) ""
}
最佳答案
我认为对 array_key_first()
进行如此多的迭代调用没有任何意义 - 事实上,只需在生成标记时使用已知的列名称来指示数据的顺序即可。每个表格行中的最后一个单元格是 uid
,因此只需将其添加到列名称列表中即可。
我已经重命名了您的许多变量,以使您的脚本更易于理解。
我不知道这个自定义函数将变得多么动态。我使用 http_build_query()
作为最佳实践 - 以便您始终生成有效的查询字符串,但如果只有字母数字键和值,则可以将其恢复为原始值直接注入(inject)到url字符串中的技术。
无论如何,当你要内爆它时,没有必要生成一个数组来返回 html 表。换句话说,只需创建一个字符串,返回它,然后回显它。
完全重写:(Demo)
function getDataTableWithoutDatabase(array $dataRow, array $columnNames, string $tableName) {
$tableRow = '<tr>';
foreach ($columnNames as $columnName) {
$tableRow .= '<td class="v-align-middle">';
if ($dataRow[$columnName]) {
$tableRow .= "<p>{$dataRow[$columnName]}</p>";
}
$tableRow .= '</td>';
}
$tableRow .= '<td><a href="../' . $tableName . 'edit?' . http_build_query([$tableName => $dataRow['uid']]) .'">Bewerken</a></td>';
$tableRow .= '</tr>';
return $tableRow;
}
$resultSet = [
['Voornaam' => '', 'uid' => '7d1f4f8e906245f', 'Achternaam' => 'Les', 'Initialen' => ''],
['Voornaam' => 'Foo', 'uid' => 'fedcba098765432', 'Achternaam' => '', 'Initialen' => ''],
['Voornaam' => '', 'uid' => '1234567890abcde', 'Achternaam' => '', 'Initialen' => 'Bar'],
];
$fieldList = [['name' => 'Voornaam'], ['name' => 'Achternaam'], ['name' => 'Initialen']];
$list = array_column($fieldList, 'name');
?>
<div class="card-body">
<table class="table table-hover demo-table-dynamic table-responsive-block" id="tableWithDynamicRows">
<thead>
<tr>
<?php echo '<th>' . implode('</th><th>', $list) . '</th>'; ?>
<th>Actie</th>
</tr>
</thead>
<tbody>
<?php
foreach ($resultSet as $row) {
echo getDataTableWithoutDatabase($row, $list, 'datalist');
}
?>
</tbody>
</table>
</div>
输出(重新标记标记后):
<div class="card-body">
<table class="table table-hover demo-table-dynamic table-responsive-block" id="tableWithDynamicRows">
<thead>
<tr>
<th>Voornaam</th>
<th>Achternaam</th>
<th>Initialen</th>
<th>Actie</th>
</tr>
</thead>
<tbody>
<tr>
<td class="v-align-middle"></td>
<td class="v-align-middle"><p>Les</p></td>
<td class="v-align-middle"></td>
<td><a href="../datalistedit?datalist=7d1f4f8e906245f">Bewerken</a></td>
</tr>
<tr>
<td class="v-align-middle"><p>Foo</p></td>
<td class="v-align-middle"></td>
<td class="v-align-middle"></td>
<td><a href="../datalistedit?datalist=fedcba098765432">Bewerken</a></td>
</tr>
<tr>
<td class="v-align-middle"></td>
<td class="v-align-middle"></td>
<td class="v-align-middle"><p>Bar</p></td>
<td><a href="../datalistedit?datalist=1234567890abcde">Bewerken</a></td>
</tr>
</tbody>
</table>
</div>
关于php - 如果列表中不存在键,则添加空行,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/60766272/