leptos::reactive::wrappers::read

Struct ArcSignal

Source
pub struct ArcSignal<T, S = SyncStorage>
where T: 'static, S: Storage<T>,
{ /* private fields */ }
Expand description

A wrapper for any kind of reference-counted reactive signal: an ArcReadSignal, ArcMemo, ArcRwSignal, or derived signal closure.

This allows you to create APIs that take any kind of ArcSignal<T> as an argument, rather than adding a generic F: Fn() -> T. Values can be access with the same function call, with(), and get() APIs as other signals.

Implementations§

Source§

impl<T> ArcSignal<T>
where SyncStorage: Storage<T>,

Source

pub fn derive( derived_signal: impl Fn() -> T + Send + Sync + 'static, ) -> ArcSignal<T>

Wraps a derived signal, i.e., any computation that accesses one or more reactive signals.

let (count, set_count) = arc_signal(2);
let double_count = ArcSignal::derive({
    let count = count.clone();
    move || count.get() * 2
});

// this function takes any kind of wrapped signal
fn above_3(arg: &ArcSignal<i32>) -> bool {
    arg.get() > 3
}

assert_eq!(above_3(&count.into()), false);
assert_eq!(above_3(&double_count), true);
Source

pub fn stored(value: T) -> ArcSignal<T>

Moves a static, nonreactive value into a signal, backed by ArcStoredValue.

Trait Implementations§

Source§

impl<V> AddAnyAttr for ArcSignal<V>
where ArcSignal<V>: Get<Value = V>, V: RenderHtml + Clone + Send + Sync + 'static, <V as Render>::State: 'static,

Source§

type Output<SomeNewAttr: Attribute> = ArcSignal<V>

The new type once the attribute has been added.
Source§

fn add_any_attr<NewAttr>( self, _attr: NewAttr, ) -> <ArcSignal<V> as AddAnyAttr>::Output<NewAttr>
where NewAttr: Attribute, <ArcSignal<V> as AddAnyAttr>::Output<NewAttr>: RenderHtml,

Adds an attribute to the view.
Source§

impl<V> AttributeValue for ArcSignal<V>
where ArcSignal<V>: Get<Value = V>, V: AttributeValue + Clone + Send + Sync + 'static, <V as AttributeValue>::State: 'static,

Source§

type AsyncOutput = ArcSignal<V>

The type once all async data have loaded.
Source§

type State = RenderEffect<<V as AttributeValue>::State>

The state that should be retained between building and rebuilding.
Source§

type Cloneable = ArcSignal<V>

A version of the value that can be cloned. This can be the same type, or a reference-counted type. Generally speaking, this does not need to refer to the same data, but should behave in the same way. So for example, making an event handler cloneable should probably make it reference-counted (so that a FnMut() continues mutating the same closure), but making a String cloneable does not necessarily need to make it an Arc<str>, as two different clones of a String will still have the same value.
Source§

type CloneableOwned = ArcSignal<V>

A cloneable type that is also 'static. This is used for spreading across types when the spreadable attribute needs to be owned. In some cases (&'a str to Arc<str>, etc.) the owned cloneable type has worse performance than the cloneable type, so they are separate.
Source§

fn html_len(&self) -> usize

An approximation of the actual length of this attribute in HTML.
Source§

fn to_html(self, key: &str, buf: &mut String)

Renders the attribute value to HTML.
Source§

fn to_template(_key: &str, _buf: &mut String)

Renders the attribute value to HTML for a <template>.
Source§

fn hydrate<const FROM_SERVER: bool>( self, key: &str, el: &Element, ) -> <ArcSignal<V> as AttributeValue>::State

Adds interactivity as necessary, given DOM nodes that were created from HTML that has either been rendered on the server, or cloned for a <template>.
Source§

fn build( self, el: &Element, key: &str, ) -> <ArcSignal<V> as AttributeValue>::State

Adds this attribute to the element during client-side rendering.
Source§

fn rebuild(self, key: &str, state: &mut <ArcSignal<V> as AttributeValue>::State)

Applies a new value for the attribute.
Source§

fn into_cloneable(self) -> <ArcSignal<V> as AttributeValue>::Cloneable

Converts this attribute into an equivalent that can be cloned.
Source§

fn into_cloneable_owned( self, ) -> <ArcSignal<V> as AttributeValue>::CloneableOwned

Converts this attributes into an equivalent that can be cloned and is 'static.
Source§

fn dry_resolve(&mut self)

“Runs” the attribute without other side effects. For primitive types, this is a no-op. For reactive types, this can be used to gather data about reactivity or about asynchronous data that needs to be loaded.
Source§

async fn resolve(self) -> <ArcSignal<V> as AttributeValue>::AsyncOutput

“Resolves” this into a form that is not waiting for any asynchronous data.
Source§

impl<T, S> Clone for ArcSignal<T, S>
where S: Storage<T>,

Source§

fn clone(&self) -> ArcSignal<T, S>

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, S> Debug for ArcSignal<T, S>
where S: Storage<T>,

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result<(), Error>

Formats the value using the given formatter. Read more
Source§

impl<T> Default for ArcSignal<T>
where T: Default + Send + Sync + 'static,

Source§

fn default() -> ArcSignal<T>

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

impl<T, S> DefinedAt for ArcSignal<T, S>
where S: Storage<T>,

Source§

fn defined_at(&self) -> Option<&'static Location<'static>>

Returns the location at which the signal was defined. This is usually simply None in release mode.
Source§

impl<T, S> From<ArcMemo<T, S>> for ArcSignal<T, S>
where S: Storage<T>,

Source§

fn from(value: ArcMemo<T, S>) -> ArcSignal<T, S>

Converts to this type from the input type.
Source§

impl<T> From<ArcReadSignal<T>> for ArcSignal<T>
where T: Send + Sync,

Source§

fn from(value: ArcReadSignal<T>) -> ArcSignal<T>

Converts to this type from the input type.
Source§

impl<T> From<ArcRwSignal<T>> for ArcSignal<T>
where T: Send + Sync,

Source§

fn from(value: ArcRwSignal<T>) -> ArcSignal<T>

Converts to this type from the input type.
Source§

impl<T> From<ArcSignal<T>> for Signal<T>
where T: Send + Sync + 'static,

Source§

fn from(value: ArcSignal<T>) -> Signal<T>

Converts to this type from the input type.
Source§

impl<T, S> From<Signal<T, S>> for ArcSignal<T, S>
where S: Storage<SignalTypes<T, S>> + Storage<T>,

Source§

fn from(value: Signal<T, S>) -> ArcSignal<T, S>

Converts to this type from the input type.
Source§

impl<T> From<T> for ArcSignal<T>
where T: Send + Sync + 'static,

Source§

fn from(value: T) -> ArcSignal<T>

Converts to this type from the input type.
Source§

impl<T> FromLocal<ArcSignal<T, LocalStorage>> for Signal<T, LocalStorage>
where T: 'static,

Source§

fn from_local(value: ArcSignal<T, LocalStorage>) -> Signal<T, LocalStorage>

Converts between the types.
Source§

impl<V> InnerHtmlValue for ArcSignal<V>
where ArcSignal<V>: Get<Value = V>, V: InnerHtmlValue + Send + Sync + Clone + 'static, <V as InnerHtmlValue>::State: 'static,

Source§

type AsyncOutput = ArcSignal<V>

The type after all async data have resolved.
Source§

type State = RenderEffect<<V as InnerHtmlValue>::State>

The view state retained between building and rebuilding.
Source§

type Cloneable = ArcSignal<V>

An equivalent value that can be cloned.
Source§

type CloneableOwned = ArcSignal<V>

An equivalent value that can be cloned and is 'static.
Source§

fn html_len(&self) -> usize

The estimated length of the HTML.
Source§

fn to_html(self, buf: &mut String)

Renders the class to HTML.
Source§

fn to_template(_buf: &mut String)

Renders the class to HTML for a <template>.
Source§

fn hydrate<const FROM_SERVER: bool>( self, el: &Element, ) -> <ArcSignal<V> as InnerHtmlValue>::State

Adds interactivity as necessary, given DOM nodes that were created from HTML that has either been rendered on the server, or cloned for a <template>.
Source§

fn build(self, el: &Element) -> <ArcSignal<V> as InnerHtmlValue>::State

Adds this class to the element during client-side rendering.
Source§

fn rebuild(self, state: &mut <ArcSignal<V> as InnerHtmlValue>::State)

Updates the value.
Source§

fn into_cloneable(self) -> <ArcSignal<V> as InnerHtmlValue>::Cloneable

Converts this to a cloneable type.
Source§

fn into_cloneable_owned( self, ) -> <ArcSignal<V> as InnerHtmlValue>::CloneableOwned

Converts this to a cloneable, owned type.
Source§

fn dry_resolve(&mut self)

“Runs” the attribute without other side effects. For primitive types, this is a no-op. For reactive types, this can be used to gather data about reactivity or about asynchronous data that needs to be loaded.
Source§

async fn resolve(self) -> <ArcSignal<V> as InnerHtmlValue>::AsyncOutput

“Resolves” this into a type that is not waiting for any asynchronous data.
Source§

impl<C> IntoClass for ArcSignal<C>
where ArcSignal<C>: Get<Value = C>, C: IntoClass + Send + Sync + Clone + 'static, <C as IntoClass>::State: 'static,

Source§

type AsyncOutput = ArcSignal<C>

The type after all async data have resolved.
Source§

type State = RenderEffect<<C as IntoClass>::State>

The view state retained between building and rebuilding.
Source§

type Cloneable = ArcSignal<C>

An equivalent value that can be cloned.
Source§

type CloneableOwned = ArcSignal<C>

An equivalent value that can be cloned and is 'static.
Source§

fn html_len(&self) -> usize

The estimated length of the HTML.
Source§

fn to_html(self, class: &mut String)

Renders the class to HTML.
Source§

fn hydrate<const FROM_SERVER: bool>( self, el: &Element, ) -> <ArcSignal<C> as IntoClass>::State

Adds interactivity as necessary, given DOM nodes that were created from HTML that has either been rendered on the server, or cloned for a <template>.
Source§

fn build(self, el: &Element) -> <ArcSignal<C> as IntoClass>::State

Adds this class to the element during client-side rendering.
Source§

fn rebuild(self, state: &mut <ArcSignal<C> as IntoClass>::State)

Updates the value.
Source§

fn into_cloneable(self) -> <ArcSignal<C> as IntoClass>::Cloneable

Converts this to a cloneable type.
Source§

fn into_cloneable_owned(self) -> <ArcSignal<C> as IntoClass>::CloneableOwned

Converts this to a cloneable, owned type.
Source§

fn dry_resolve(&mut self)

“Runs” the attribute without other side effects. For primitive types, this is a no-op. For reactive types, this can be used to gather data about reactivity or about asynchronous data that needs to be loaded.
Source§

async fn resolve(self) -> <ArcSignal<C> as IntoClass>::AsyncOutput

“Resolves” this into a type that is not waiting for any asynchronous data.
Source§

fn reset(state: &mut <ArcSignal<C> as IntoClass>::State)

Reset the class list to the state before this class was added.
Source§

const TEMPLATE: &'static str = ""

The HTML that should be included in a <template>.
Source§

const MIN_LENGTH: usize = _

The minimum length of the HTML.
Source§

fn to_template(class: &mut String)

Renders the class to HTML for a <template>.
Source§

impl<V> IntoProperty for ArcSignal<V>
where ArcSignal<V>: Get<Value = V>, V: IntoProperty + Send + Sync + Clone + 'static, <V as IntoProperty>::State: 'static,

Source§

type State = RenderEffect<<V as IntoProperty>::State>

The view state retained between building and rebuilding.
Source§

type Cloneable = ArcSignal<V>

An equivalent value that can be cloned.
Source§

type CloneableOwned = ArcSignal<V>

An equivalent value that can be cloned and is 'static.
Source§

fn hydrate<const FROM_SERVER: bool>( self, el: &Element, key: &str, ) -> <ArcSignal<V> as IntoProperty>::State

Adds the property on an element created from HTML.
Source§

fn build(self, el: &Element, key: &str) -> <ArcSignal<V> as IntoProperty>::State

Adds the property during client-side rendering.
Source§

fn rebuild(self, state: &mut <ArcSignal<V> as IntoProperty>::State, key: &str)

Updates the property with a new value.
Source§

fn into_cloneable(self) -> <ArcSignal<V> as IntoProperty>::Cloneable

Converts this to a cloneable type.
Source§

fn into_cloneable_owned(self) -> <ArcSignal<V> as IntoProperty>::CloneableOwned

Converts this to a cloneable, owned type.
Source§

impl<C> IntoStyle for ArcSignal<C>
where ArcSignal<C>: Get<Value = C>, C: IntoStyle + Clone + Send + Sync + 'static, <C as IntoStyle>::State: 'static,

Source§

type AsyncOutput = ArcSignal<C>

The type after all async data have resolved.
Source§

type State = RenderEffect<<C as IntoStyle>::State>

The view state retained between building and rebuilding.
Source§

type Cloneable = ArcSignal<C>

An equivalent value that can be cloned.
Source§

type CloneableOwned = ArcSignal<C>

An equivalent value that can be cloned and is 'static.
Source§

fn to_html(self, style: &mut String)

Renders the style to HTML.
Source§

fn hydrate<const FROM_SERVER: bool>( self, el: &Element, ) -> <ArcSignal<C> as IntoStyle>::State

Adds interactivity as necessary, given DOM nodes that were created from HTML that has either been rendered on the server, or cloned for a <template>.
Source§

fn build(self, el: &Element) -> <ArcSignal<C> as IntoStyle>::State

Adds this style to the element during client-side rendering.
Source§

fn rebuild(self, state: &mut <ArcSignal<C> as IntoStyle>::State)

Updates the value.
Source§

fn into_cloneable(self) -> <ArcSignal<C> as IntoStyle>::Cloneable

Converts this to a cloneable type.
Source§

fn into_cloneable_owned(self) -> <ArcSignal<C> as IntoStyle>::CloneableOwned

Converts this to a cloneable, owned type.
Source§

fn dry_resolve(&mut self)

“Runs” the attribute without other side effects. For primitive types, this is a no-op. For reactive types, this can be used to gather data about reactivity or about asynchronous data that needs to be loaded.
Source§

async fn resolve(self) -> <ArcSignal<C> as IntoStyle>::AsyncOutput

“Resolves” this into a type that is not waiting for any asynchronous data.
Source§

fn reset(state: &mut <ArcSignal<C> as IntoStyle>::State)

Reset the styling to the state before this style was added.
Source§

impl<T, S> PartialEq for ArcSignal<T, S>
where S: Storage<T>,

Source§

fn eq(&self, other: &ArcSignal<T, S>) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
Source§

impl<T, S> ReadUntracked for ArcSignal<T, S>
where S: Storage<T>,

Source§

fn custom_try_read( &self, ) -> Option<Option<<ArcSignal<T, S> as ReadUntracked>::Value>>

Overriding the default auto implemented Read::try_read to combine read and track, to avoid 2 clones and just have 1 in the SignalTypes::DerivedSignal.

Source§

type Value = ReadGuard<T, SignalReadGuard<T, S>>

The guard type that will be returned, which can be dereferenced to the value.
Source§

fn try_read_untracked( &self, ) -> Option<<ArcSignal<T, S> as ReadUntracked>::Value>

Returns the guard, or None if the signal has already been disposed.
Source§

fn read_untracked(&self) -> Self::Value

Returns the guard. Read more
Source§

impl<V> Render for ArcSignal<V>
where ArcSignal<V>: Get<Value = V>, V: Render + Clone + Send + Sync + 'static, <V as Render>::State: 'static,

Source§

type State = RenderEffectState<<V as Render>::State>

The “view state” for this type, which can be retained between updates. Read more
Source§

fn build(self) -> <ArcSignal<V> as Render>::State

Creates the view for the first time, without hydrating from existing HTML.
Source§

fn rebuild(self, state: &mut <ArcSignal<V> as Render>::State)

Updates the view with new data.
Source§

impl<V> RenderHtml for ArcSignal<V>
where ArcSignal<V>: Get<Value = V>, V: RenderHtml + Clone + Send + Sync + 'static, <V as Render>::State: 'static,

Source§

const MIN_LENGTH: usize = 0usize

The minimum length of HTML created when this view is rendered.
Source§

type AsyncOutput = ArcSignal<V>

The type of the view after waiting for all asynchronous data to load.
Source§

fn dry_resolve(&mut self)

“Runs” the view without other side effects. For primitive types, this is a no-op. For reactive types, this can be used to gather data about reactivity or about asynchronous data that needs to be loaded.
Source§

async fn resolve(self) -> <ArcSignal<V> as RenderHtml>::AsyncOutput

Waits for any asynchronous sections of the view to load and returns the output.
Source§

fn html_len(&self) -> usize

An estimated length for this view, when rendered to HTML. Read more
Source§

fn to_html_with_buf( self, buf: &mut String, position: &mut Position, escape: bool, mark_branches: bool, )

Renders a view to HTML, writing it into the given buffer.
Source§

fn to_html_async_with_buf<const OUT_OF_ORDER: bool>( self, buf: &mut StreamBuilder, position: &mut Position, escape: bool, mark_branches: bool, )
where ArcSignal<V>: Sized,

Renders a view into a buffer of (synchronous or asynchronous) HTML chunks.
Source§

fn hydrate<const FROM_SERVER: bool>( self, cursor: &Cursor, position: &PositionState, ) -> <ArcSignal<V> as Render>::State

Makes a set of DOM nodes rendered from HTML interactive. Read more
Source§

const EXISTS: bool = true

Whether this should actually exist in the DOM, if it is the child of an element.
Source§

fn to_html(self) -> String
where Self: Sized,

Renders a view to an HTML string.
Source§

fn to_html_branching(self) -> String
where Self: Sized,

Renders a view to HTML with branch markers. This can be used to support libraries that diff HTML pages against one another, by marking sections of the view that branch to different types with marker comments.
Source§

fn to_html_stream_in_order(self) -> StreamBuilder
where Self: Sized,

Renders a view to an in-order stream of HTML.
Source§

fn to_html_stream_in_order_branching(self) -> StreamBuilder
where Self: Sized,

Renders a view to an in-order stream of HTML with branch markers. This can be used to support libraries that diff HTML pages against one another, by marking sections of the view that branch to different types with marker comments.
Source§

fn to_html_stream_out_of_order(self) -> StreamBuilder
where Self: Sized,

Renders a view to an out-of-order stream of HTML.
Source§

fn to_html_stream_out_of_order_branching(self) -> StreamBuilder
where Self: Sized,

Renders a view to an out-of-order stream of HTML with branch markers. This can be used to support libraries that diff HTML pages against one another, by marking sections of the view that branch to different types with marker comments.
Source§

fn hydrate_from<const FROM_SERVER: bool>(self, el: &Element) -> Self::State
where Self: Sized,

Hydrates using RenderHtml::hydrate, beginning at the given element.
Source§

fn hydrate_from_position<const FROM_SERVER: bool>( self, el: &Element, position: Position, ) -> Self::State
where Self: Sized,

Hydrates using RenderHtml::hydrate, beginning at the given element and position.
Source§

impl<T, S> Track for ArcSignal<T, S>
where S: Storage<T>,

Source§

fn track(&self)

Subscribes to this signal in the current reactive scope without doing anything with its value.
Source§

impl<T, S> Eq for ArcSignal<T, S>
where S: Storage<T>,

Auto Trait Implementations§

§

impl<T, S> Freeze for ArcSignal<T, S>

§

impl<T, S = SyncStorage> !RefUnwindSafe for ArcSignal<T, S>

§

impl<T, S> Send for ArcSignal<T, S>
where T: Send + Sync,

§

impl<T, S> Sync for ArcSignal<T, S>
where T: Send + Sync,

§

impl<T, S> Unpin for ArcSignal<T, S>

§

impl<T, S = SyncStorage> !UnwindSafe for ArcSignal<T, S>

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<V, Key, Sig, T> BindAttribute<Key, Sig, T> for V
where V: AddAnyAttr, Key: AttributeKey, Sig: IntoSplitSignal<Value = T>, T: FromEventTarget + AttributeValue + PartialEq + Sync + 'static, Signal<BoolOrT<T>>: IntoProperty, <Sig as IntoSplitSignal>::Read: Get<Value = T> + Send + Sync + Clone + 'static, <Sig as IntoSplitSignal>::Write: Send + Clone + 'static, Element: GetValue<T>,

Source§

type Output = <V as AddAnyAttr>::Output<Bind<Key, T, <Sig as IntoSplitSignal>::Read, <Sig as IntoSplitSignal>::Write>>

The type of the element with the two-way binding added.
Source§

fn bind( self, key: Key, signal: Sig, ) -> <V as BindAttribute<Key, Sig, T>>::Output

Adds a two-way binding to the element, which adds an attribute and an event listener to the element when the element is created or hydrated. 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 u8)

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

impl<T, K, V> CustomAttribute<K, V> for T

Source§

fn attr(self, key: K, value: V) -> Self::Output<CustomAttr<K, V>>

Adds an HTML attribute by key and value.
Source§

impl<V, T, P, D> DirectiveAttribute<T, P, D> for V
where V: AddAnyAttr, D: IntoDirective<T, P>, P: Clone + 'static, T: 'static,

Source§

type Output = <V as AddAnyAttr>::Output<Directive<T, D, P>>

The type of the element with the directive added.
Source§

fn directive( self, handler: D, param: P, ) -> <V as DirectiveAttribute<T, P, D>>::Output

Adds a directive to the element, which runs some custom logic in the browser when the element is created or hydrated.
Source§

impl<Q, K> Equivalent<K> for Q
where Q: Eq + ?Sized, K: Borrow<Q> + ?Sized,

Source§

fn equivalent(&self, key: &K) -> bool

Checks if this value is equivalent to the given key. Read more
Source§

impl<Q, K> Equivalent<K> for Q
where Q: Eq + ?Sized, K: Borrow<Q> + ?Sized,

Source§

fn equivalent(&self, key: &K) -> bool

Compare self to key and return true if they are equal.
Source§

impl<Q, K> Equivalent<K> for Q
where Q: Eq + ?Sized, K: Borrow<Q> + ?Sized,

Source§

fn equivalent(&self, key: &K) -> bool

Checks if this value is equivalent to the given key. Read more
Source§

impl<T> From<!> for T

Source§

fn from(t: !) -> T

Converts to this type from the input type.
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<S, T> FromStream<T> for S
where S: From<ArcReadSignal<Option<T>>> + Send + Sync, T: Send + Sync + 'static,

Source§

fn from_stream(stream: impl Stream<Item = T> + Send + 'static) -> S

Creates a signal that contains the latest value of the stream.
Source§

fn from_stream_unsync(stream: impl Stream<Item = T> + 'static) -> S

Creates a signal that contains the latest value of the stream.
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> IntoAny for T
where T: Send + RenderHtml + 'static, <T as Render>::State: 'static,

Source§

fn into_any(self) -> AnyView

Converts the view into a type-erased AnyView.
Source§

impl<T> IntoAttributeValue for T
where T: AttributeValue,

Source§

type Output = T

The attribute value into which this type can be converted.
Source§

fn into_attribute_value(self) -> <T as IntoAttributeValue>::Output

Consumes this value, transforming it into an attribute value.
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> IntoRender for T
where T: Render,

Source§

type Output = T

The renderable type into which this type can be converted.
Source§

fn into_render(self) -> <T as IntoRender>::Output

Consumes this value, transforming it into the renderable type.
Source§

impl<T> IntoView for T
where T: Render + RenderHtml + Send,

Source§

fn into_view(self) -> View<T>

Wraps the inner type.
Source§

impl<T> Read for T
where T: Track + ReadUntracked,

Source§

type Value = <T as ReadUntracked>::Value

The guard type that will be returned, which can be dereferenced to the value.
Source§

fn try_read(&self) -> Option<<T as Read>::Value>

Subscribes to the signal, and returns the guard, or None if the signal has already been disposed.
Source§

fn read(&self) -> Self::Value

Subscribes to the signal, and returns the guard. Read more
Source§

impl<T> StorageAccess<T> for T

Source§

fn as_borrowed(&self) -> &T

Borrows the value.
Source§

fn into_taken(self) -> T

Takes the value.
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> With for T
where T: Read,

Source§

type Value = <<T as Read>::Value as Deref>::Target

The type of the value contained in the signal.
Source§

fn try_with<U>(&self, fun: impl FnOnce(&<T as With>::Value) -> U) -> Option<U>

Subscribes to the signal, applies the closure to the value, and returns the result, or None if the signal has already been disposed.
Source§

fn with<U>(&self, fun: impl FnOnce(&Self::Value) -> U) -> U

Subscribes to the signal, applies the closure to the value, and returns the result. Read more
Source§

impl<T> WithUntracked for T

Source§

type Value = <<T as ReadUntracked>::Value as Deref>::Target

The type of the value contained in the signal.
Source§

fn try_with_untracked<U>( &self, fun: impl FnOnce(&<T as WithUntracked>::Value) -> U, ) -> Option<U>

Applies the closure to the value, and returns the result, or None if the signal has already been disposed.
Source§

fn with_untracked<U>(&self, fun: impl FnOnce(&Self::Value) -> U) -> U

Applies the closure to the value, and returns the result. Read more
Source§

impl<T> ErasedDestructor for T
where T: 'static,

Source§

impl<T> MaybeSendSync for T