我试着这样做:
var script:HTMLScriptElement = document.getElementsByName("script")[0];
alert(script.type);
但是它给了我一个错误
Cannot convert 'Node' to 'HTMLScriptElement': Type 'Node' is missing property 'defer' from type 'HTMLScriptElement'
(elementName: string) => NodeList
我不能访问脚本元素的'type'成员,除非我将其转换为正确的类型,但我不知道如何做到这一点。我查了文件和样本,但什么都没找到。
作为cerperformance答案的扩展,如果你使用声明合并来增加标准定义库的文档接口,你可以为getElementsByName方法(或任何其他方法)添加一个泛型覆盖,参数默认设置为HTMLElement,以模拟非泛型版本的行为时,类型参数没有显式提供:
interface Document
extends Node,
DocumentAndElementEventHandlers,
DocumentOrShadowRoot,
GlobalEventHandlers,
NonElementParentNode,
ParentNode,
XPathEvaluatorBase {
getElementsByName<T extends HTMLElement>(elementName: string) : NodeListOf<T>;
}
然后在用户代码中,你可以显式地传递所需的类型:
const scripts = document.getElementsByName<HTMLScriptElement>("name"); //NodeListOf<HTMLScriptElement>
操场上
注意,您需要重新指定extends列表,因为只有相同的声明才能合并。
作为cerperformance答案的扩展,如果你使用声明合并来增加标准定义库的文档接口,你可以为getElementsByName方法(或任何其他方法)添加一个泛型覆盖,参数默认设置为HTMLElement,以模拟非泛型版本的行为时,类型参数没有显式提供:
interface Document
extends Node,
DocumentAndElementEventHandlers,
DocumentOrShadowRoot,
GlobalEventHandlers,
NonElementParentNode,
ParentNode,
XPathEvaluatorBase {
getElementsByName<T extends HTMLElement>(elementName: string) : NodeListOf<T>;
}
然后在用户代码中,你可以显式地传递所需的类型:
const scripts = document.getElementsByName<HTMLScriptElement>("name"); //NodeListOf<HTMLScriptElement>
操场上
注意,您需要重新指定extends列表,因为只有相同的声明才能合并。