扩展 getElementsByClassName 或 querySelectorAll 在 TypeScript 中会出现错误

问题描述 投票:0回答:1

我使用以下代码将 DOM 节点列表转换为数组:

const elements = [...document.getElementsByClassName(selector)];

但是使用 TypeScript 我收到如下错误:

Type 'HTMLCollectionOf<Element>' is not an array type or does not have a '[Symbol.iterator]()' method that returns an iterator.

我不知道在这种情况下我应该做什么。我尝试这样输入:

const elements: HTMLElement[] = [...document.getElementsByClassName(selector)];

但是没用。

这是我的 TypeScript 配置文件 (

tsconfig.json
):

{
    "compilerOptions": {
        "target": "es5",
        "module": "umd",
        "sourceMap": true,
        "outDir": "dist",
        "strict": true,
        "esModuleInterop": true,
        "downlevelIteration": true
    }
}
javascript arrays typescript spread-syntax
1个回答
1
投票

问题是默认情况下 Typescript 将使用 .slice。

您应该添加标志 --downlevelIteration 使其适用于所有迭代器,包括 html 集合。

https://www.typescriptlang.org/docs/handbook/compiler-options.html

你应该有 dom.iterable 作为它工作的库。您当前没有指定库,因此根据您的目标使用默认值,这就是它不起作用的原因。

© www.soinside.com 2019 - 2024. All rights reserved.