登录
首页 >  文章 >  前端

如何使用HTML DOM输出数组?

时间:2024-10-28 17:36:48 176浏览 收藏

今日不肯埋头,明日何以抬头!每日一句努力自己的话哈哈~哈喽,今天我将给大家带来一篇《如何使用HTML DOM输出数组? 》,主要内容是讲解等等,感兴趣的朋友可以收藏或者有更好的建议在评论提出,我都会认真看的!大家一起进步,一起学习!

如何使用HTML DOM输出数组?

问题分析:使用HTML DOM输出数组

在该问题中,我们是通过HTML DOM来实现对数组的输出,具体做法是点击“保存”按钮添加数据行到列表中,然后点击“上传”按钮输出列表数据为数组形式。

实现方法

  1. 获取输入值:保存按钮的点击事件中,获取输入姓名和年龄的值,并拼接成列表中的一行数据();
  2. 动态添加数据行:将拼接好的列表行添加到table中的tbody(list)中;
  3. 上传输出:上传按钮的点击事件中,获取table中的所有数据行,遍历每一行,提取姓名和年龄值,并推入到result数组中;
  4. 输出结果:最后,将result数组的内容打印到控制台。

解决方案

然而,在提供的问题代码中,有两个问题:

  1. 不能直接使用foreach遍历NodeList:NodeList虽然类似数组,但本质上不是数组,不能直接使用foreach遍历,需要借助展开运算符(...)将其转换为真正的数组;
  2. 内部HTML拼接导致多余的td:innerHTML拼接时会在每一行后多拼接一个带有空格的td,需要过滤掉这样的td。

修正后代码

//...

//上传
document.getElementById("upload").addEventListener("click", () => {
  let listElement = document.getElementById("list");
  let lineElement = listElement.querySelectorAll("tr");
  let result = [];
  [...lineElement].forEach((item) => {
    let tds = item.querySelectorAll("td");
    if (tds.length) {
      let name = tds[0].innerText;
      let age = tds[1].innerText;
      result.push({ name, age });
    }
  });
  console.log(result);
});

以上就是《如何使用HTML DOM输出数组? 》的详细内容,更多关于的资料请关注golang学习网公众号!

相关阅读
更多>
最新阅读
更多>
课程推荐
更多>