Skip to main content

ReadSignal

Struct ReadSignal 

Source
pub struct ReadSignal<T, S = SyncStorage> { /* private fields */ }
Expand description

An arena-allocated getter for a reactive signal.

A signal is a piece of data that may change over time, and notifies other code when it has changed.

This is an arena-allocated signal, which is Copy and is disposed when its reactive Owner cleans up. For a reference-counted signal that lives as long as a reference to it is alive, see ArcReadSignal.

§Core Trait Implementations

  • .get() clones the current value of the signal. If you call it within an effect, it will cause that effect to subscribe to the signal, and to re-run whenever the value of the signal changes.
    • .get_untracked() clones the value of the signal without reactively tracking it.
  • .read() returns a guard that allows accessing the value of the signal by reference. If you call it within an effect, it will cause that effect to subscribe to the signal, and to re-run whenever the value of the signal changes.
    • .read_untracked() gives access to the current value of the signal without reactively tracking it.
  • .with() allows you to reactively access the signal’s value without cloning by applying a callback function.
    • .with_untracked() allows you to access the signal’s value by applying a callback function without reactively tracking it.
  • .to_stream() converts the signal to an async stream of values.
  • ::from_stream() converts an async stream of values into a signal containing the latest value.

§Examples

let (count, set_count) = signal(0);

// calling .get() clones and returns the value
assert_eq!(count.get(), 0);
// calling .read() accesses the value by reference
assert_eq!(count.read(), 0);

Trait Implementations§

Source§

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

Source§

type Output<SomeNewAttr: Attribute> = ReadSignal<V, S>

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

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

Adds an attribute to the view.
Source§

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

Source§

type AsyncOutput = ReadSignal<V, S>

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 = ReadSignal<V, S>

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 = ReadSignal<V, S>

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, ) -> <ReadSignal<V, S> 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, ) -> <ReadSignal<V, S> as AttributeValue>::State

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

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

Applies a new value for the attribute.
Source§

fn into_cloneable(self) -> <ReadSignal<V, S> as AttributeValue>::Cloneable

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

fn into_cloneable_owned( self, ) -> <ReadSignal<V, S> 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) -> <ReadSignal<V, S> as AttributeValue>::AsyncOutput

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

impl<T, S> Clone for ReadSignal<T, S>

Source§

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

Returns a duplicate 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 ReadSignal<T, S>
where S: Debug,

Source§

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

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

impl<T, S> DefinedAt for ReadSignal<T, S>

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> Dispose for ReadSignal<T, S>

Source§

fn dispose(self)

Disposes of the signal. This: Read more
Source§

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

Source§

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

Converts to this type from the input type.
Source§

impl<T> From<ReadSignal<Option<T>>> for MaybeProp<T>
where T: Send + Sync,

Source§

fn from(value: ReadSignal<Option<T>>) -> MaybeProp<T>

Converts to this type from the input type.
Source§

impl<T> From<ReadSignal<Option<T>, LocalStorage>> for MaybeProp<T, LocalStorage>
where T: Send + Sync,

Source§

fn from( value: ReadSignal<Option<T>, LocalStorage>, ) -> MaybeProp<T, LocalStorage>

Converts to this type from the input type.
Source§

impl<T> From<ReadSignal<T>> for MaybeProp<T>
where T: Send + Sync + Clone,

Source§

fn from(value: ReadSignal<T>) -> MaybeProp<T>

Converts to this type from the input type.
Source§

impl<T> From<ReadSignal<T>> for MaybeSignal<T>
where T: Send + Sync,

Source§

fn from(value: ReadSignal<T>) -> MaybeSignal<T>

Converts to this type from the input type.
Source§

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

Source§

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

Converts to this type from the input type.
Source§

impl<T> From<ReadSignal<T, LocalStorage>> for MaybeProp<T, LocalStorage>
where T: Send + Sync + Clone,

Source§

fn from(value: ReadSignal<T, LocalStorage>) -> MaybeProp<T, LocalStorage>

Converts to this type from the input type.
Source§

impl<T> From<ReadSignal<T, LocalStorage>> for MaybeSignal<T, LocalStorage>

Source§

fn from(value: ReadSignal<T, LocalStorage>) -> MaybeSignal<T, LocalStorage>

Converts to this type from the input type.
Source§

impl<T> From<ReadSignal<T, LocalStorage>> for Signal<T, LocalStorage>
where T: 'static,

Source§

fn from(value: ReadSignal<T, LocalStorage>) -> Signal<T, LocalStorage>

Converts to this type from the input type.
Source§

impl<T, S> From<ReadSignal<T, S>> for ArcReadSignal<T>
where T: 'static, S: Storage<ArcReadSignal<T>>,

Source§

fn from(value: ReadSignal<T, S>) -> ArcReadSignal<T>

Converts to this type from the input type.
Source§

impl<T, S> From<ReadSignal<T, S>> for ArcSignal<T, S>
where S: Storage<ArcReadSignal<T>> + Storage<T>,

Source§

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

Converts to this type from the input type.
Source§

impl<V, S> From<ReadSignal<V, S>> for TextProp
where V: Into<Oco<'static, str>> + Clone + Send + Sync + 'static, ReadSignal<V, S>: Get<Value = V>, S: Storage<V> + Storage<Option<V>> + Send + Sync + 'static,

Source§

fn from(s: ReadSignal<V, S>) -> TextProp

Converts to this type from the input type.
Source§

impl<T> FromLocal<ArcReadSignal<T>> for ReadSignal<T, LocalStorage>
where T: 'static,

Source§

fn from_local(value: ArcReadSignal<T>) -> ReadSignal<T, LocalStorage>

Converts between the types.
Source§

impl<T, S> Hash for ReadSignal<T, S>

Source§

fn hash<H>(&self, state: &mut H)
where H: Hasher,

Feeds this value into the given Hasher. Read more
1.3.0 · Source§

fn hash_slice<H>(data: &[Self], state: &mut H)
where H: Hasher, Self: Sized,

Feeds a slice of this type into the given Hasher. Read more
Source§

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

Source§

type AsyncOutput = ReadSignal<V, S>

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 = ReadSignal<V, S>

An equivalent value that can be cloned.
Source§

type CloneableOwned = ReadSignal<V, S>

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, ) -> <ReadSignal<V, S> 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) -> <ReadSignal<V, S> as InnerHtmlValue>::State

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

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

Updates the value.
Source§

fn into_cloneable(self) -> <ReadSignal<V, S> as InnerHtmlValue>::Cloneable

Converts this to a cloneable type.
Source§

fn into_cloneable_owned( self, ) -> <ReadSignal<V, S> 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) -> <ReadSignal<V, S> as InnerHtmlValue>::AsyncOutput

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

impl<V, S> IntoClass for ReadSignal<V, S>
where V: IntoClass + Clone + Send + Sync + 'static, <V as IntoClass>::State: 'static, ReadSignal<V, S>: Get<Value = V>, S: Storage<V> + Storage<Option<V>> + Send + Sync + 'static,

Source§

type AsyncOutput = ReadSignal<V, S>

The type after all async data have resolved.
Source§

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

The view state retained between building and rebuilding.
Source§

type Cloneable = ReadSignal<V, S>

An equivalent value that can be cloned.
Source§

type CloneableOwned = ReadSignal<V, S>

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, ) -> <ReadSignal<V, S> 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) -> <ReadSignal<V, S> as IntoClass>::State

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

fn rebuild(self, state: &mut <ReadSignal<V, S> as IntoClass>::State)

Updates the value.
Source§

fn into_cloneable(self) -> <ReadSignal<V, S> as IntoClass>::Cloneable

Converts this to a cloneable type.
Source§

fn into_cloneable_owned(self) -> <ReadSignal<V, S> 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) -> <ReadSignal<V, S> as IntoClass>::AsyncOutput

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

fn reset(state: &mut <ReadSignal<V, S> 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<T, S> IntoInner for ReadSignal<T, S>
where S: Storage<ArcReadSignal<T>>,

Source§

type Value = T

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

fn into_inner(self) -> Option<<ReadSignal<T, S> as IntoInner>::Value>

Returns the inner value if this is the only reference to the signal. Otherwise, returns None and drops this reference. Read more
Source§

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

Source§

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

The view state retained between building and rebuilding.
Source§

type Cloneable = ReadSignal<V, S>

An equivalent value that can be cloned.
Source§

type CloneableOwned = ReadSignal<V, S>

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

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

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

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

Adds the property during client-side rendering.
Source§

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

Updates the property with a new value.
Source§

fn into_cloneable(self) -> <ReadSignal<V, S> as IntoProperty>::Cloneable

Converts this to a cloneable type.
Source§

fn into_cloneable_owned( self, ) -> <ReadSignal<V, S> as IntoProperty>::CloneableOwned

Converts this to a cloneable, owned type.
Source§

impl<V, S> IntoStyle for ReadSignal<V, S>
where V: IntoStyle + Clone + Send + Sync + 'static, <V as IntoStyle>::State: 'static, ReadSignal<V, S>: Get<Value = V>, S: Storage<V> + Storage<Option<V>> + Send + Sync + 'static,

Source§

type AsyncOutput = ReadSignal<V, S>

The type after all async data have resolved.
Source§

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

The view state retained between building and rebuilding.
Source§

type Cloneable = ReadSignal<V, S>

An equivalent value that can be cloned.
Source§

type CloneableOwned = ReadSignal<V, S>

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, ) -> <ReadSignal<V, S> 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) -> <ReadSignal<V, S> as IntoStyle>::State

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

fn rebuild(self, state: &mut <ReadSignal<V, S> as IntoStyle>::State)

Updates the value.
Source§

fn into_cloneable(self) -> <ReadSignal<V, S> as IntoStyle>::Cloneable

Converts this to a cloneable type.
Source§

fn into_cloneable_owned(self) -> <ReadSignal<V, S> 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) -> <ReadSignal<V, S> as IntoStyle>::AsyncOutput

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

fn reset(state: &mut <ReadSignal<V, S> as IntoStyle>::State)

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

impl<V, S> IntoStyleValue for ReadSignal<V, S>
where V: IntoStyleValue + Send + Sync + Clone + 'static, ReadSignal<V, S>: Get<Value = V>, S: Storage<V> + Storage<Option<V>> + Send + Sync + 'static,

Source§

type AsyncOutput = ReadSignal<V, S>

The type after all async data have resolved.
Source§

type State = (Arc<str>, RenderEffect<<V as IntoStyleValue>::State>)

The view state retained between building and rebuilding.
Source§

type Cloneable = ReadSignal<V, S>

An equivalent value that can be cloned.
Source§

type CloneableOwned = ReadSignal<V, S>

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

fn to_html(self, name: &str, style: &mut String)

Renders the style to HTML.
Source§

fn build( self, style: &CssStyleDeclaration, name: &str, ) -> <ReadSignal<V, S> as IntoStyleValue>::State

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

fn rebuild( self, style: &CssStyleDeclaration, name: &str, state: &mut <ReadSignal<V, S> as IntoStyleValue>::State, )

Updates the value.
Source§

fn hydrate( self, style: &CssStyleDeclaration, name: &str, ) -> <ReadSignal<V, S> as IntoStyleValue>::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 into_cloneable(self) -> <ReadSignal<V, S> as IntoStyleValue>::Cloneable

Converts this to a cloneable type.
Source§

fn into_cloneable_owned( self, ) -> <ReadSignal<V, S> as IntoStyleValue>::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) -> <ReadSignal<V, S> as IntoStyleValue>::AsyncOutput

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

impl<T, S> IsDisposed for ReadSignal<T, S>

Source§

fn is_disposed(&self) -> bool

If true, the signal cannot be accessed without a panic.
Source§

impl<T, S> PartialEq for ReadSignal<T, S>

Source§

fn eq(&self, other: &ReadSignal<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 ReadSignal<T, S>
where T: 'static, S: Storage<ArcReadSignal<T>>,

Source§

type Value = ReadGuard<T, Plain<T>>

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

fn try_read_untracked( &self, ) -> Option<<ReadSignal<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§

fn custom_try_read(&self) -> Option<Option<Self::Value>>

This is a backdoor to allow overriding the Read::try_read implementation despite it being auto implemented. Read more
Source§

impl<V, S> Render for ReadSignal<V, S>
where V: Render + Clone + Send + Sync + 'static, <V as Render>::State: 'static, ReadSignal<V, S>: Get<Value = V>, S: Storage<V> + Storage<Option<V>> + Send + Sync + '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) -> <ReadSignal<V, S> as Render>::State

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

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

Updates the view with new data.
Source§

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

Source§

const MIN_LENGTH: usize = 0

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

type AsyncOutput = ReadSignal<V, S>

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

type Owned = ReadSignal<V, S>

An equivalent value that is 'static.
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) -> <ReadSignal<V, S> 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, extra_attrs: Vec<AnyAttribute>, )

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, extra_attrs: Vec<AnyAttribute>, )
where ReadSignal<V, S>: 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, ) -> <ReadSignal<V, S> as Render>::State

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

fn into_owned(self) -> <ReadSignal<V, S> as RenderHtml>::Owned

Convert into the equivalent value that is 'static.
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_async( self, cursor: &Cursor, position: &PositionState, ) -> impl Future<Output = Self::State>

Asynchronously makes a set of DOM nodes rendered from HTML interactive. Read more
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, St> Serialize for ReadSignal<T, St>
where T: Serialize + 'static, St: Storage<ArcReadSignal<T>>,

Source§

fn serialize<S>( &self, serializer: S, ) -> Result<<S as Serializer>::Ok, <S as Serializer>::Error>
where S: Serializer,

Serialize this value into the given Serde serializer. Read more
Source§

impl<T, S> Copy for ReadSignal<T, S>

Source§

impl<T, S> Eq for ReadSignal<T, S>

Auto Trait Implementations§

§

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

§

impl<T, S> RefUnwindSafe for ReadSignal<T, S>

§

impl<T, S> Send for ReadSignal<T, S>

§

impl<T, S> Sync for ReadSignal<T, S>

§

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

§

impl<T, S> UnwindSafe for ReadSignal<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, dest: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dest. 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<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<E, T, Request, Encoding> FromReq<Patch<Encoding>, Request, E> for T
where Request: Req<E> + Send + 'static, Encoding: Decodes<T>, E: FromServerFnError,

Source§

async fn from_req(req: Request) -> Result<T, E>

Attempts to deserialize the arguments from a request.
Source§

impl<E, T, Request, Encoding> FromReq<Post<Encoding>, Request, E> for T
where Request: Req<E> + Send + 'static, Encoding: Decodes<T>, E: FromServerFnError,

Source§

async fn from_req(req: Request) -> Result<T, E>

Attempts to deserialize the arguments from a request.
Source§

impl<E, T, Request, Encoding> FromReq<Put<Encoding>, Request, E> for T
where Request: Req<E> + Send + 'static, Encoding: Decodes<T>, E: FromServerFnError,

Source§

async fn from_req(req: Request) -> Result<T, E>

Attempts to deserialize the arguments from a request.
Source§

impl<E, Encoding, Response, T> FromRes<Patch<Encoding>, Response, E> for T
where Response: ClientRes<E> + Send, Encoding: Decodes<T>, E: FromServerFnError,

Source§

async fn from_res(res: Response) -> Result<T, E>

Attempts to deserialize the outputs from a response.
Source§

impl<E, Encoding, Response, T> FromRes<Post<Encoding>, Response, E> for T
where Response: ClientRes<E> + Send, Encoding: Decodes<T>, E: FromServerFnError,

Source§

async fn from_res(res: Response) -> Result<T, E>

Attempts to deserialize the outputs from a response.
Source§

impl<E, Encoding, Response, T> FromRes<Put<Encoding>, Response, E> for T
where Response: ClientRes<E> + Send, Encoding: Decodes<T>, E: FromServerFnError,

Source§

async fn from_res(res: Response) -> Result<T, E>

Attempts to deserialize the outputs from a response.
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,

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> IntoMaybeErased for T
where T: RenderHtml,

Source§

type Output = T

The type of the output.
Source§

fn into_maybe_erased(self) -> <T as IntoMaybeErased>::Output

Converts the view into a type-erased view if in erased mode.
Source§

impl<T, S> IntoOptionGetter<T, SignalMarker> for S
where S: Get<Value = Option<T>> + Clone + Send + Sync + 'static,

Source§

fn into_option_getter(self) -> OptionGetter<T>

Converts the given value into an OptionGetter.
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<E, T, Request> IntoReq<DeleteUrl, Request, E> for T
where Request: ClientReq<E>, T: Serialize + Send, E: FromServerFnError,

Source§

fn into_req(self, path: &str, accepts: &str) -> Result<Request, E>

Attempts to serialize the arguments into an HTTP request.
Source§

impl<E, T, Request> IntoReq<GetUrl, Request, E> for T
where Request: ClientReq<E>, T: Serialize + Send, E: FromServerFnError,

Source§

fn into_req(self, path: &str, accepts: &str) -> Result<Request, E>

Attempts to serialize the arguments into an HTTP request.
Source§

impl<E, T, Encoding, Request> IntoReq<Patch<Encoding>, Request, E> for T
where Request: ClientReq<E>, Encoding: Encodes<T>, E: FromServerFnError,

Source§

fn into_req(self, path: &str, accepts: &str) -> Result<Request, E>

Attempts to serialize the arguments into an HTTP request.
Source§

impl<E, T, Request> IntoReq<PatchUrl, Request, E> for T
where Request: ClientReq<E>, T: Serialize + Send, E: FromServerFnError,

Source§

fn into_req(self, path: &str, accepts: &str) -> Result<Request, E>

Attempts to serialize the arguments into an HTTP request.
Source§

impl<E, T, Encoding, Request> IntoReq<Post<Encoding>, Request, E> for T
where Request: ClientReq<E>, Encoding: Encodes<T>, E: FromServerFnError,

Source§

fn into_req(self, path: &str, accepts: &str) -> Result<Request, E>

Attempts to serialize the arguments into an HTTP request.
Source§

impl<E, T, Request> IntoReq<PostUrl, Request, E> for T
where Request: ClientReq<E>, T: Serialize + Send, E: FromServerFnError,

Source§

fn into_req(self, path: &str, accepts: &str) -> Result<Request, E>

Attempts to serialize the arguments into an HTTP request.
Source§

impl<E, T, Encoding, Request> IntoReq<Put<Encoding>, Request, E> for T
where Request: ClientReq<E>, Encoding: Encodes<T>, E: FromServerFnError,

Source§

fn into_req(self, path: &str, accepts: &str) -> Result<Request, E>

Attempts to serialize the arguments into an HTTP request.
Source§

impl<E, T, Request> IntoReq<PutUrl, Request, E> for T
where Request: ClientReq<E>, T: Serialize + Send, E: FromServerFnError,

Source§

fn into_req(self, path: &str, accepts: &str) -> Result<Request, E>

Attempts to serialize the arguments into an HTTP request.
Source§

impl<E, Response, Encoding, T> IntoRes<Patch<Encoding>, Response, E> for T
where Response: TryRes<E>, Encoding: Encodes<T>, E: FromServerFnError + Send, T: Send,

Source§

async fn into_res(self) -> Result<Response, E>

Attempts to serialize the output into an HTTP response.
Source§

impl<E, Response, Encoding, T> IntoRes<Post<Encoding>, Response, E> for T
where Response: TryRes<E>, Encoding: Encodes<T>, E: FromServerFnError + Send, T: Send,

Source§

async fn into_res(self) -> Result<Response, E>

Attempts to serialize the output into an HTTP response.
Source§

impl<E, Response, Encoding, T> IntoRes<Put<Encoding>, Response, E> for T
where Response: TryRes<E>, Encoding: Encodes<T>, E: FromServerFnError + Send, T: Send,

Source§

async fn into_res(self) -> Result<Response, E>

Attempts to serialize the output into an HTTP response.
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> ReactiveNode for T
where T: AsSubscriberSet + DefinedAt,

Source§

fn mark_dirty(&self)

Notifies the source’s dependencies that it has changed.
Source§

fn mark_check(&self)

Notifies the source’s dependencies that it may have changed.
Source§

fn mark_subscribers_check(&self)

Marks that all subscribers need to be checked.
Source§

fn update_if_necessary(&self) -> bool

Regenerates the value for this node, if needed, and returns whether it has actually changed or not.
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> SerializableKey for T

Source§

fn ser_key(&self) -> String

Serializes the key to a unique string. Read more
Source§

impl<T> Source for T
where T: AsSubscriberSet + DefinedAt,

Source§

fn clear_subscribers(&self)

Remove all subscribers from this source’s list of dependencies.
Source§

fn add_subscriber(&self, subscriber: AnySubscriber)

Adds a subscriber to this source’s list of dependencies.
Source§

fn remove_subscriber(&self, subscriber: &AnySubscriber)

Removes a subscriber from this source’s list of dependencies.
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> Track for T

Source§

fn track(&self)

Subscribes to this signal in the current reactive scope without doing anything with its value.
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