Struct dioxus_core::LazyNodes

source ·
pub struct LazyNodes<'a, 'b> { /* private fields */ }
Expand description

A concrete type provider for closures that build VNode structures.

This struct wraps lazy structs that build VNode trees Normally, we cannot perform a blanket implementation over closures, but if we wrap the closure in a concrete type, we can use it for different branches in matching.

LazyNodes::new(|f| f.element("div", [], [], [] None))

Implementations§

source§

impl<'a, 'b> LazyNodes<'a, 'b>

source

pub fn new(val: impl FnOnce(&'a ScopeState) -> VNode<'a> + 'b) -> Self

Create a new LazyNodes closure, optimistically placing it onto the stack.

If the closure cannot fit into the stack allocation (16 bytes), then it is placed on the heap. Most closures will fit into the stack, and is the most optimal way to use the creation function.

source

pub fn call(self, f: &'a ScopeState) -> VNode<'a>

Call the closure with the given factory to produce real VNode.

let f = LazyNodes::new(move |f| f.element("div", [], [], [] None));

let node = f.call(cac);

Trait Implementations§

source§

impl<'a, 'b> IntoDynNode<'a, ()> for LazyNodes<'a, 'b>

source§

fn into_vnode(self, cx: &'a ScopeState) -> DynamicNode<'a>

Consume this item along with a scopestate and produce a DynamicNode Read more

Auto Trait Implementations§

§

impl<'a, 'b> !RefUnwindSafe for LazyNodes<'a, 'b>

§

impl<'a, 'b> !Send for LazyNodes<'a, 'b>

§

impl<'a, 'b> !Sync for LazyNodes<'a, 'b>

§

impl<'a, 'b> !Unpin for LazyNodes<'a, 'b>

§

impl<'a, 'b> !UnwindSafe for LazyNodes<'a, 'b>

Blanket Implementations§

source§

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

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
source§

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

source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

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

source§

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

Mutably borrows from an owned value. Read more
source§

impl<T> From<T> for T

source§

fn from(t: T) -> T

Returns the argument unchanged.

source§

impl<T, U> Into<U> for Twhere 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, U> TryFrom<U> for Twhere U: Into<T>,

§

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 Twhere U: TryFrom<T>,

§

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.