flutter - 为什么在Flutter Sink中添加数据不起作用?

标签 flutter dart rxdart

目的很简单。获取数据后,可以通过特定的字符串集进行过滤。因此,我最初使用“全部”进行过滤,这意味着显示所有数据,并在单击任何选择的筹码时基于该特定字符串进行过滤。一切正常,除了从api调用加载数据后不显示所有数据。即使我再次热装,它也会显示完整列表数据。因此,基本上在Sink中添加字符串数据是行不通的。我认为我犯了一些愚蠢的错误,但无法弄清楚。需要建议。

BLOC类(class)

final Application _application;

ProductListScreenBloc(this._application);
int totalPages = 1;


final _productList = BehaviorSubject<List<Product>>();
Observable<List<Product>> _filteredProductList = Observable.empty();
final _filterName = BehaviorSubject<String>();


Stream<List<Product>> get productList => _productList.stream;
Stream<List<Product>> get filteredProductList => _filteredProductList;
Sink<String> get filterName => _filterName;


void loadBrandWiseProductList(
  String categorySlug, String brandSlug, int pageNo) {

if (totalPages >= pageNo) { //for pagination

  StreamSubscription subscription = _application.productListRepository
      .getBrandWiseProductList(categorySlug, brandSlug, pageNo)
      .listen((ProductListResponse response) {
    if (_productList.value == null) {

      totalPages = response.totalPage;
      _productList.add(response.productList);

      filterName.add('all');

      _filteredProductList = Observable.combineLatest2(
              _filterName, _productList, applyModelFilter)
          .asBroadcastStream();
    } 
  });

  }
 }

List<Product> applyModelFilter(
String filter,
List<Product> products,
) {
if (filter == 'all') {
  return products;
} else {
  return products
      .where((seriesSLug) => seriesSLug.series.slug == filter)
      .toList();
 }
}

UI Widget类
 class _AllSeriesModelListScreenState extends State<AllSeriesModelListScreen> {
 AllSeriesModelListScreenArguments allSeriesModelListScreenArguments;

 ProductListScreenBloc bloc;

 int _selectedSeriesChipValue = -1;
 int _pageNo = 1;

 @override
 void initState() {
 super.initState();
 }

 @override
 void dispose() {
 super.dispose();
 bloc.dispose();
}

@override
Widget build(BuildContext context) {
RouteSettings settings = ModalRoute.of(context).settings;
allSeriesModelListScreenArguments = settings.arguments;

_init();

return Scaffold(
  body: CustomScrollView(
    slivers: <Widget>[
      StreamBuilder(
          stream: bloc.filteredProductList,
          builder: (context, snapshot) {
            if (snapshot.hasData) {
              List<Product> productList = snapshot.data;

              return SliverPadding(
                padding: EdgeInsets.symmetric(
                  vertical: 8.0,
                  horizontal: 10.0,
                ),
                sliver: SliverGrid(
                  gridDelegate: SliverGridDelegateWithFixedCrossAxisCount(
                    crossAxisCount: 3,
                    crossAxisSpacing: 0.0,
                    mainAxisSpacing: 8.0,
                  ),
                  delegate: SliverChildListDelegate(
                    buildModelGridList(productList),
                  ),
                ),
              );
            } else {
              return SliverList(
                delegate: SliverChildListDelegate([
                  PaddingWithTitle(
                    title: 'No Model Available',
                  ),
                ]),
              );
            }
          })
    ],
  ),
 );
}

void _init() {
 if (null == bloc) {
  bloc = ProductListScreenBloc(
    AppProvider.getApplication(context),
  );

  bloc.loadBrandWiseProductList(
      allSeriesModelListScreenArguments.categorySlug,
      allSeriesModelListScreenArguments.brandSlug,
      _pageNo);

   }
  }
}

最佳答案

我相信您错过了这两行内容。

final _filterName = BehaviorSubject<String>();
Sink<String> get filterName => _filterName;

您没有暴露水槽。 BehaviorSubject只是一个具有默认值的StreamController,并为最后一个值缓存。因此,作为每个Stream Controller ,它都有2个 Prop -水槽和小溪。推送数据,您需要访问接收器。
为此,您需要输入
StreamSink<String> get filterName => _filterName.sink;

加上为什么您在行为主题中没有种子值(value)?
必须具有该“默认”值
final _filterName = BehaviorSubject<String>(seedValue: '');

关于flutter - 为什么在Flutter Sink中添加数据不起作用?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/59500366/

相关文章:

flutter - 可以在 Flutter 的文本小部件中识别字符的全局位置

flutter - 如何在应用程序中为几个屏幕制作通用抽屉

flutter - 改变 flutter_bloc 中的 `currentState` 属性

dart - Dart部署查询-如何在服务器+配置管理上部署Dart代码

dart - Flutter - BLoC 模式 - 如何使用流调用另一个小部件的方法,即动画?

flutter - 抖动错误:未为 'combineLatest4'类型定义 'Observable'方法

Flutter spaceBetween 在 Card 小部件内的 Column 中不起作用

Flutter国际版本冲突

flutter - 布局和逻辑可以分开吗?

flutter - 无法在 Flutter Web 上使用图像选择器选择图像(MissingPluginException)