Refs
The ref
keyword can be used inside of any HTML element or component to get the DOM Element
that the item is attached to. This can be used to make changes to the DOM outside of the view
lifecycle method.
This is useful for getting ahold of canvas elements, or scrolling to different sections of a page. For example, using a NodeRef
in a component’s rendered
method allows you to make draw calls to a canvas element after it has been rendered from view
.
The syntax is:
use web_sys::Element;
use yew::{html, Component, Context, Html, NodeRef};
struct Comp {
node_ref: NodeRef,
}
impl Component for Comp {
type Message = ();
type Properties = ();
fn create(_ctx: &Context<Self>) -> Self {
Self {
node_ref: NodeRef::default(),
}
}
fn view(&self, _ctx: &Context<Self>) -> Html {
html! {
<div ref={self.node_ref.clone()}></div>
}
}
fn rendered(&mut self, _ctx: &Context<Self>, _first_render: bool) {
let has_attributes = self.node_ref
.cast::<Element>()
.unwrap()
.has_attributes();
}
}