重庆分公司,新征程启航
为企业提供网站建设、域名注册、服务器等服务
小编给大家分享一下利用FutureBuilder提高开发效率的方法,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!
我们拥有十多年网页设计和网站建设经验,从网站策划到网站制作,我们的网页设计师为您提供的解决方案。为企业提供成都做网站、网站建设、微信开发、小程序定制开发、手机网站开发、H5响应式网站、等业务。无论您有什么样的网站设计或者设计方案要求,我们都将富于创造性的提供专业设计服务并满足您的需求。
常见场景
展示请求按钮
用户点击按钮,显示loading
展示数据或者错误
抽象模式
展示请求按钮(初始状态)
用户点击按钮,显示loading(请求中状态)
展示数据或者错误 (结束状态(成功或失败))
转换成程序语言
以上三种现实情况对应 AsyncSnapshot 三个状态
ConnectionState.none 初始态
ConnectionState.waiting 请求态
ConnectionState.done 完成态
snapshot.hasError 完成(异常)
snapshot.hasData 完成(正常)
使用 FutureBuilder 处理这个场景
这篇文章的主角,FutureBuilder 就是为了解决这个问题存在的。它接收一个 Future 请求,和对应以上几种情况的 widget 回调。即可把数据和界面串联起来,避免额外声明仅用来传递数据用的变量。
提前声明了一个 _showResult 变量,以表示页面是否触发请求。
并且封装了一个 _fetch() 网络请求。
Future
请求的结果是任意的,不管是封装好的对象,map,list,都可以,只要是一个 Future
把这个 Future 调用安放到 FutureBuilder 的 future 参数上, 并用 _showResult 来控制何时来触发这个请求。
FutureBuilder( future: _showResult ? _fetch() : null, ... )
再把每一个 Future 的结果对应的 widget 设置到 builder 参数上:
FutureBuilder( ... builder: (context, snapshot) { switch (snapshot.connectionState) { case ConnectionState.none: // -------- 初始态 return RaisedButton( onPressed: () { setState(() { _showResult = true; // 点击按钮,触发请求 }); }, child: Text("start"), ); case ConnectionState.waiting: // -------- 请求态 return CircularProgressIndicator(); case ConnectionState.done: // -------- 完成态 if (snapshot.hasError) { // 异常 return Text( '${snapshot.error}', style: TextStyle(color: Colors.red), ); } else { // 正常 return Text(snapshot.data["name"]); } break; default: break; } return Container(); }, ),
总结
FutureBuilder 把数据请求的 Future
以上是“利用FutureBuilder提高开发效率的方法”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注创新互联行业资讯频道!