StreamProvider<T> class

Listens to a Stream and exposes its content to child and descendants.

Its main use-case is to provide to a large number of a component the content of a Stream, without caring about reacting to events. A typical example would be to expose the battery level, or a Firebase query.

Trying to use Stream to replace ChangeNotifier is outside of the scope of this class.

It is considered an error to pass a stream that can emit errors without providing a catchError method.

initialData determines the value exposed until the Stream emits a value.

By default, StreamProvider considers that the Stream listened uses immutable data. As such, it will not rebuild dependents if the previous and the new value are ==. To change this behavior, pass a custom updateShouldNotify.

See also:

Inheritance

Constructors

StreamProvider({Key? key, required Create<Stream<T>?> create, required T initialData, ErrorBuilder<T>? catchError, UpdateShouldNotify<T>? updateShouldNotify, bool? lazy, TransitionBuilder? builder, Component? child})
Creates a Stream using create and subscribes to it.
StreamProvider.value({Key? key, required Stream<T>? value, required T initialData, ErrorBuilder<T>? catchError, UpdateShouldNotify<T>? updateShouldNotify, bool? lazy, TransitionBuilder? builder, Component? child})
Listens to value and expose it to all of StreamProvider descendants.

Properties

builder → TransitionBuilder?
Syntax sugar for obtaining a BuildContext that can read the provider created.
finalinherited
hashCode int
The hash code for this object.
no setterinherited
key → Key?
Controls how one component replaces another component in the tree.
finalinherited
runtimeType Type
A representation of the runtime type of the object.
no setterinherited

Methods

build(BuildContext context) Iterable<Component>
Describes the part of the user interface represented by this component.
inherited
buildWithChild(BuildContext context, Component? child) Iterable<Component>
A build method that receives an extra child parameter.
inherited
createElement() → _InheritedProviderElement<T>
Creates a StatelessElement to manage this component's location in the tree.
inherited
noSuchMethod(Invocation invocation) → dynamic
Invoked when a nonexistent method or property is accessed.
inherited
toString() String
A string representation of this object.
inherited

Operators

operator ==(Object other) bool
The equality operator.
inherited