未捕获的类型错误:btnz.appendChild 不是函数

如何解决未捕获的类型错误:btnz.appendChild 不是函数

const btnList = [
    {
        id: 'all',content: 'All'
    },{
        id: 'br',content: 'breakfast'
    },{
        id: 'dn',content: 'dinner'
    }
]
const btnz = document.querySelector('.btnz');

 // for version 1 I declared newBtn beforehand: let newBtn = ''
 btnList.forEach(btn => {
        // version 1: 
        newBtn += `<button id="${btn.id}">${btn.content}</button>`
        // version 2:
        let newBtn = document.createElement('button');
        newBtn.setAttribute('id',btn.id);
        newBtn.textContent = btn.content;
        btnz.appendChild(newBtn);
    })

这是我的 JS,我只有一个带有类 btnz 的简单 div,我想在其中添加新的动态按钮。你能解释一下是什么问题吗?为什么没有一个版本不起作用。

解决方法

Document.querySelectorAll() 返回静态(非实时)NodeList。你应该使用索引。

如果您有类 IDLE 的单个元素,那么我建议您使用 Document.querySelector(),它返回文档中的 first 元素匹配指定的选择器或选择器组。如果未找到匹配项,则返回 null。

btnz

,

在版本 1 中,您将获得 newBtn 作为字符串,因此您需要执行 innerHTML 在 DOM 中添加。

const btnList = [{
    id: 'all',content: 'All'
  },{
    id: 'br',content: 'breakfast'
  },{
    id: 'dn',content: 'dinner'
  }
];

let newBtn = '';
const btnz = document.querySelector("div.btnz");
btnList.forEach(btn => {
  // version 1: 
  newBtn += `<button id="${btn.id}">${btn.content}</button>`
})
btnz.innerHTML = newBtn;
<div class="btnz"></div>

对于版本 2,您需要在 appendChildNodeElement

const btnList = [{
    id: 'all',content: 'dinner'
  }
]

let newBtn = '';
const btnz = document.querySelector("div.btnz");
btnList.forEach(btn => {
  // version 2:
  let newBtn = document.createElement('button');
  newBtn.setAttribute('id',btn.id);
  newBtn.textContent = btn.content;
  btnz.appendChild(newBtn);
})
<div class="btnz"></div>

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其他元素将获得点击?
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。)
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbcDriver发生异常。为什么?
这是用Java进行XML解析的最佳库。
Java的PriorityQueue的内置迭代器不会以任何特定顺序遍历数据结构。为什么?
如何在Java中聆听按键时移动图像。
Java“Program to an interface”。这是什么意思?
Java在半透明框架/面板/组件上重新绘画。
Java“ Class.forName()”和“ Class.forName()。newInstance()”之间有什么区别?
在此环境中不提供编译器。也许是在JRE而不是JDK上运行?
Java用相同的方法在一个类中实现两个接口。哪种接口方法被覆盖?
Java 什么是Runtime.getRuntime()。totalMemory()和freeMemory()?
java.library.path中的java.lang.UnsatisfiedLinkError否*****。dll
JavaFX“位置是必需的。” 即使在同一包装中
Java 导入两个具有相同名称的类。怎么处理?
Java 是否应该在HttpServletResponse.getOutputStream()/。getWriter()上调用.close()?
Java RegEx元字符(。)和普通点?