php - 如果列表中不存在键,则添加空行

标签 php datatable

亲爱的之前已经提供过帮助的人们。

我有一个结合了自定义列和自定义数据的表。但正如您所看到的,有些数据不在右列下。

enter image description here

我的表代码:

                        <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

中的示例

enter image description here

$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/

相关文章:

php - Laravel 的灯箱

php - htaccess https 从非 www 重定向到 www

c# - 需要在 Winform 应用程序的 DataGrid View 中针对每一行放置一个 RadioButton

sorting - Primefaces "sortBy="不起作用

php - sed 无法编辑 ssl.conf "Permission denied"

php - 使用 PHP 和 CURL 发布多维数组

PHP MySQL 无效查询 bool(False)

c# - 从包含多个表的数据集中找到最小值和最大值

c# - 将 linq 结果获取到数据表的通用方法,用于通过多个选择选择新的

c# - 如何从 session 对象将 ListBox 绑定(bind)到 DataTable?