web-sys
中的继承
JS 类之间的继承是 Web 上 DOM 工作方式的基础,因此,web-sys
提供对该继承层次结构的访问非常重要!使用 web-sys
时,您可以通过几种方式访问继承层次结构。
使用 Deref
访问父类
与 Rust 中的智能指针类似,web_sys
中的所有类型都实现了 Deref
到其父 JS 类。这意味着,例如,如果您有一个 web_sys::Element
,您可以隐式地从它创建一个 web_sys::Node
#![allow(unused)] fn main() { let element: &Element = ...; element.append_child(..); // call a method on `Node` method_expecting_a_node(&element); // coerce to `&Node` implicitly let node: &Node = &element; // explicitly coerce to `&Node` }
使用 Deref
允许您以符合人体工程学的方式向上转换继承层次结构到父类及其以上,从而使用 .
运算符访问所有方法。
使用 AsRef
访问父类
除了 Deref
之外,AsRef
特性还为 web_sys
中的所有类型实现了继承层次结构中的所有类型。例如,对于 HtmlAnchorElement
类型,您会发现
#![allow(unused)] fn main() { impl AsRef<HtmlElement> for HtmlAnchorElement impl AsRef<Element> for HtmlAnchorElement impl AsRef<Node> for HtmlAnchorElement impl AsRef<EventTarget> for HtmlAnchorElement impl AsRef<Object> for HtmlAnchorElement impl AsRef<JsValue> for HtmlAnchorElement }
您可以使用 .as_ref()
从 web_sys
中的类型显式地获取对任何父类的引用。请注意,由于 AsRef
实现的数量,您可能需要类型推断指导。
使用 JsCast
访问子类
最后,wasm_bindgen::JsCast
特性可用于实现各种类型之间的转换。它支持类型之间的静态未经检查的转换,以及类型之间的动态运行时检查转换(使用 instanceof
)。
有关此的更多文档可以在 特性本身 上找到