首页 > 解决方案 > 模板文字 HTML 表格

问题描述

我正在尝试创建一个表的 div,但只坚持添加到每个表的第一个项目。我得到的表只有第一个键值对。我正在通过我的数据数组进行映射,但无法访问表中的键和值。我觉得我被困在 createTableData 函数上。

HTML

<body>
<div class="container-fluid">
    <div class="jumbotron">
        <h1 class="text-center mb-3">
            Active Directory Replication Health
        </h1>
    </div>



<div id="table"></div>


</div>


<script src="js/jquery-3.3.1.min.js"></script>
<script src="js/bootstrap.bundle.min.js"></script>
<script src="js/script.js"></script>

脚本

var data = [

{
    "DC":  "SV07CTDC1",
    "Connectivity":  "Passed",
    "Advertising":  "Failed"
},
{
    "DC":  "SVGCCTDC1",
    "Connectivity":  "Passed",
    "Advertising":  "Failed"
}
];


function createTableData(dc ){

for( key in dc )
    return  `
        <tr>
            <td> ${key} </td>
            <td> ${dc[key]} </td>
        </tr>

`

}


function createTable(dc) {
return `
    <div class="col-md-3 col-sm-6  ">
        <table class="table table-dark table-striped table-bordered table-hover">

                ${createTableData(dc)}



        </table>
    </div>  
`
}






document.getElementById("table").innerHTML = `
<div class="row">
    ${data.map(createTable).join("")}
</div>
`

标签: javascriptjavascript-objectstemplate-literals

解决方案


在你的函数中试试这个createTableData..

    function createTableData(dc) {
        var html = ''
        for (key in dc) {
        html += `
        <tr>
            <td> ${key} </td>
            <td> ${dc[key]} </td>
        </tr>            
        `
        }
        return html
    }

推荐阅读