首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >使用Supabase查询的颤振FutureBuilder

使用Supabase查询的颤振FutureBuilder
EN

Stack Overflow用户
提问于 2022-01-07 05:10:02
回答 2查看 462关注 0票数 0

我无法让Supabase查询与flutter一起工作。下面是代码的一个示例:

代码语言:javascript
复制
child: FutureBuilder<PostgrestResponse<dynamic>>(
   future: supabase.from('products').select().execute(),
      builder: (context, snapshot) {
         if (snapshot.connectionState != ConnectionState.active) {
            return const Center(
               child: SizedBox(
                  child: CircularProgressIndicator(),
                      width: 60,
                      height: 60,
                  ),
               );
            } else {
               return GridView.builder(
                  gridDelegate:
                      SliverGridDelegateWithFixedCrossAxisCount(
                        crossAxisCount: gridColumns,
                        crossAxisSpacing: 10,
                        mainAxisSpacing: 10,
                      ),
                      itemCount: snapshot.data!.length, // this line is causing an error
                      ...

我不知道如何转换快照的长度。它本来是要把这个变成流线型的--它会工作的。所以,我想要的是一个基本的例子,用supabase来使用一个未来构建器。

EN

回答 2

Stack Overflow用户

发布于 2022-01-07 05:45:54

您可以使用if (snapshot.hasData)代替检查快照连接状态。因为它将不包括任何数据,并且连接状态没有活动。

这样您就可以将代码更改为;

代码语言:javascript
复制
child: FutureBuilder<PostgrestResponse<dynamic>>(
   future: supabase.from('products').select().execute(),
      builder: (context, snapshot) {
         if (!snapshot.hasData) {
            return const Center(
               child: SizedBox(
                  child: CircularProgressIndicator(),
                      width: 60,
                      height: 60,
                  ),
               );
            } else {
               return GridView.builder(
                  gridDelegate:
                      SliverGridDelegateWithFixedCrossAxisCount(
                        crossAxisCount: gridColumns,
                        crossAxisSpacing: 10,
                        mainAxisSpacing: 10,
                      ),
                      itemCount: snapshot.data!.length, // this line is causing an error
                      ...
票数 0
EN

Stack Overflow用户

发布于 2022-08-14 06:34:32

在调试代码时,响应将以snapshot.data.data的形式出现

因此,计数值可以由

代码语言:javascript
复制
itemCount: snapshot.data.data?.length,
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/70616858

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档