Flutter踩坑小总结01----FutureBuilder

本文介绍了Flutter中的异步组件FutureBuilder的使用方法,包括源码解析、官方Demo分析,强调了在使用FutureBuilder时需要注意避免重复调用接口的问题。此外,还探讨了FutureBuilder与上拉加载下拉刷新插件EasyRefresh的结合使用,提供了相关代码示例。

关于组件FutureBuilder

FutureBuilder是Flutter的一个异步组件,返回值是一个Futter,当需要网络请求等异步操作时,就可以用到这个组件,比如需要请求网络数据后再显示页面,否则就显示等待图或者占位图等。

FutureBuilder的使用方法

FutureBuilder的源码

class FutureBuilder<T> extends StatefulWidget {
   
   
	const FutureBuilder({
   
   
		 Key key,
		this.future,
		this.initialData,
		@required this.builder,
	}) : assert(builder != null),
		super(key: key);
	final AsyncWidgetBuilder<T> builder;
	
	...
	
	@override
	State<FutureBuilder<T>> createState() => _FutureBuilderState<T>();
}

class _FutureBuilderState<T> extends State<FutureBuilder<T>> {
   
   
	...
	@override
	Widget build(BuildContext context) => widget.builder(context, _snapshot);
	...
	
}

可以看到build方法直接返回了用户设置的参数的builder方法。

FutureBuilder的两个重要参数:

  1. future:这里需要返回一个Futter,来实现异步请求网络、IO等方法。
  2. builder:这里需要返回一个widget,即根据返回的数据生成,builder的两个参数分别是环境变量context和连接状态snapshot。

官方Demo

FutureBuilder<String>(
  future: _calculation, // a previously-obtained Future<String> or null
  builder: (BuildContext context, AsyncSnapshot<String> snapshot) 
评论 3
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值