在使用Flutter 进行demo调试、项目研发的时候,你是否为下拉刷新组件发愁,你是否为初始转圈、空数据页面发愁、网络差或服务器超时的错误页面发愁,如果有,请您了解一下这个物超所值的组件:flutter_allroundrefresh 。
flutter_allroundrefresh 特性
- 页面初始转圈
- 手机无网络错误页面
- 下拉刷新
- 上拉加载更多
- 网络差或服务器超时错误页面
- 无数据错误页面
- 登录失效处理
- 错误页面重试机制
- 定制转圈
- 定制错误页面
- 定制/适配状态码
- 支持国际化
- 支持 android 、ios
废话不多说:
Flutter Pub组件库之 flutter_allroundrefresh 地址
Github之 flutter_allroundrefresh 地址 欢迎 start
效果图&截图(在文章底部,由于图片较多较大,需要先看效果的童鞋请滑到最后)
**使用 flutter_allroundrefresh **
1.添加依赖
dependencies:
flutter_allroundrefresh: ^2.0.0
2.引入
import 'package:flutter_allroundrefresh/future_refresh.dart';
3.在入口方法中进行初始化
AFutureWidget.init( );
3.1.在入口方法中进行初始化(init方法中配置国际化)
AFutureWidget.init( loadingText: '加载中...',...);
4.具体页面的使用
class SimplePage3 extends StatefulWidget {
@override
_SimplePage3State createState() => _SimplePage3State();}
class _SimplePage3State extends State<SimplePage3> with TickerProviderStateMixin {
var page = 1;
List<SimpleDataBean> modelList = [];
@override
Widget build(BuildContext context) {
return Scaffold(
appBar: AppBar( title: const Text('AFutureWidget 组件DEMO'),),
body: AFutureWidget(
childWidget: yourContentWidget(),//必填
//errorWidget: YourError1Widget(),//支持自定义
//progressWidget: YourProgress2Widget(),//支持自定义
fRefresh: SimpleDao.getData10(page: 1),//必填,page 必须写1
fLoading: SimpleDao.getData10(page: page),//有加载更多必填
onLoadingCallback: () {page = page + 1;setState(() {});},//有加载更多必填
onRefreshCallback: () {page = 1;modelList.clear();setState(() {}); },//必填
tokenInvalidCallback: () { },,//登录失效回调
dataCallback: (List<dynamic> data) {
data.forEach((v) {
modelList.add(new SimpleDataBean.fromJson(v));
});
setState(() {});
},//必填
),
);
}
Widget yourContentWidget() {
return ListView.builder(
itemCount: modelList.length,
itemBuilder: (BuildContext context, int index) {
return Container(
alignment: Alignment.center,
height: 80.0,
child: Text('${modelList[index].name}'),
); },);
}
}
5.接口API返回的json格式说明(若你的后台有自己的code规则则需要在初始化方法AFutureWidget.init();中进行适配)
{
"code": "默认200访问成功,404无数据,900登录失效",
"msg": "",
"data": {},// "data": [],
}