使用Firestore的snapshot.forEach创建表

时间:2018-12-17 06:31:13

标签: javascript arrays firebase google-cloud-firestore

我正在尝试将填充有Firestore对象的数组输出到表上,但仅显示表上方的最后一个对象

<table class="darkTable">
    <thead>
        <tr>
            <th>List of Available Shows</th>
        </tr>
    </thead>
    <tbody>
        <tr>
            <div id="showList"></div>
        </tr>
    </tbody>
</table>

<script>
  firebase.firestore().collection('TV Shows').get().then(snapshot => {

        var i = 0;
        var array = [];

        snapshot.forEach(doc => {

            array[i] = doc.data().show.name;

            //console.log(doc.data().show.name);
            //showList.innerHTML = array[i] + "<br />"; 

            showList.innerHTML = '<td>' + array[i] + '</td>';
            i++;
        });

    }); 
</script>

这是我处理td代码行的方式吗?

2 个答案:

答案 0 :(得分:0)

您将在循环的每次迭代中重置整个showList元素:

showList.innerHTML = '<td>' + array[i] + '</td>';

我怀疑您的意思是每次都附加在它上面,或者每次都重新设置它。也许尝试在每次迭代时构建一个字符串,然后在循环结束后设置整个对象。

答案 1 :(得分:0)

假设此标记:

<div id="showList"></div>

然后它像这样工作:

firebase.firestore().collection('TV Shows').get().then(snapshot => {
    var showList = document.getElementById('showList');
    var html = '<table class="darkTable"><thead><tr>';

    html += '<th>List of Available Shows</th>';
    /* add further columns into here, alike the one above. */

    html += '</tr></thead><tbody>';
    snapshot.forEach(doc => {
        html += '<tr>';

        html += '<td>' + doc.data().show.name + '</td>';
        /* add further columns into here, alike the one above. */

        html += '</tr>';
    });
    html += '</tbody></table>';
    showList.append(html);
});