Struct leptos_dom::NodeRef

source ·
pub struct NodeRef<T: ElementDescriptor + 'static> { /* private fields */ }
Expand description

Contains a shared reference to a DOM node created while using the view macro to create your UI.

use leptos::html::Input;

#[component]
pub fn MyComponent() -> impl IntoView {
    let input_ref = create_node_ref::<Input>();

    let on_click = move |_| {
        let node =
            input_ref.get().expect("input_ref should be loaded by now");
        // `node` is strongly typed
        // it is dereferenced to an `HtmlInputElement` automatically
        log!("value is {:?}", node.value())
    };

    view! {
      <div>
      // `node_ref` loads the input
      <input _ref=input_ref type="text"/>
      // the button consumes it
      <button on:click=on_click>"Click me"</button>
      </div>
    }
}

Implementations§

source§

impl<T: ElementDescriptor + 'static> NodeRef<T>

source

pub fn new() -> Self

Creates a shared reference to a DOM node created while using the view macro to create your UI.

This is identical to create_node_ref.


use leptos::html::Input;

#[component]
pub fn MyComponent() -> impl IntoView {
    let input_ref = NodeRef::<Input>::new();

    let on_click = move |_| {
        let node =
            input_ref.get().expect("input_ref should be loaded by now");
        // `node` is strongly typed
        // it is dereferenced to an `HtmlInputElement` automatically
        log!("value is {:?}", node.value())
    };

    view! {
      <div>
          // `node_ref` loads the input
          <input _ref=input_ref type="text"/>
          // the button consumes it
          <button on:click=on_click>"Click me"</button>
      </div>
    }
}
source

pub fn get(&self) -> Option<HtmlElement<T>>
where T: Clone,

Gets the element that is currently stored in the reference.

This tracks reactively, so that node references can be used in effects. Initially, the value will be None, but once it is loaded the effect will rerun and its value will be Some(Element).

source

pub fn get_untracked(&self) -> Option<HtmlElement<T>>
where T: Clone,

Gets the element that is currently stored in the reference.

This does not track reactively.

source

pub fn on_load<F>(self, f: F)
where T: Clone, F: FnOnce(HtmlElement<T>) + 'static,

Runs the provided closure when the NodeRef has been connected with it’s HtmlElement.

Trait Implementations§

source§

impl<T: ElementDescriptor> Clone for NodeRef<T>

source§

fn clone(&self) -> Self

Returns a copy of the value. Read more
1.0.0 · source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
source§

impl<T: ElementDescriptor + 'static> Default for NodeRef<T>

source§

fn default() -> Self

Returns the “default value” for a type. Read more
source§

impl<T: ElementDescriptor + 'static> Copy for NodeRef<T>

Auto Trait Implementations§

§

impl<T> Freeze for NodeRef<T>

§

impl<T> !RefUnwindSafe for NodeRef<T>

§

impl<T> !Send for NodeRef<T>

§

impl<T> !Sync for NodeRef<T>

§

impl<T> Unpin for NodeRef<T>
where T: Unpin,

§

impl<T> !UnwindSafe for NodeRef<T>

Blanket Implementations§

source§

impl<T> Any for T
where T: 'static + ?Sized,

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
source§

impl<T> Borrow<T> for T
where T: ?Sized,

source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
source§

impl<T> CloneToUninit for T
where T: Clone,

source§

unsafe fn clone_to_uninit(&self, dst: *mut T)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dst. Read more
source§

impl<T> From<T> for T

source§

fn from(t: T) -> T

Returns the argument unchanged.

source§

impl<T> Instrument for T

source§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided Span, returning an Instrumented wrapper. Read more
source§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
source§

impl<T, U> Into<U> for T
where U: From<T>,

source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

source§

impl<T> IntoEither for T

source§

fn into_either(self, into_left: bool) -> Either<Self, Self>

Converts self into a Left variant of Either<Self, Self> if into_left is true. Converts self into a Right variant of Either<Self, Self> otherwise. Read more
source§

fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
where F: FnOnce(&Self) -> bool,

Converts self into a Left variant of Either<Self, Self> if into_left(&self) returns true. Converts self into a Right variant of Either<Self, Self> otherwise. Read more
source§

impl<T> ToOwned for T
where T: Clone,

source§

type Owned = T

The resulting type after obtaining ownership.
source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

source§

type Error = Infallible

The type returned in the event of a conversion error.
source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
source§

impl<T> WithSubscriber for T

source§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a WithDispatch wrapper. Read more
source§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a WithDispatch wrapper. Read more