Flutter之下拉刷新和上拉加载

一、下拉刷新

在Flutter中有一个RefreshIndicator,它是一个下拉刷新的widget,通过它我们可实现列表的下拉刷新的操作。

 

二、上拉加载

在Flutter中有一个ScrollController 列表支持设置controller参数,通过ScrollController监听列表滚动的位置,来实现加载更多的功能。

 

demo:

import 'package:flutter/material.dart';


void main() => runApp(MyApp());

List<String> list = ['北京','上海','广州','深圳','杭州','苏州','成都','重庆','宁夏','银川'];
int index = 0;

class MyApp extends StatefulWidget {
  MyApp({Key key}) : super(key: key);

  @override
  _MyAppState createState() {
    return _MyAppState();
  }
}

class _MyAppState extends State<MyApp> {
  ScrollController _scrollController = ScrollController();
  @override
  void initState() {
    _scrollController.addListener((){
      if(_scrollController.position.pixels==_scrollController.position.maxScrollExtent){
        _loadData();
      }
    });
    super.initState();
  }

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

  @override
  Widget build(BuildContext context) {
    return new MaterialApp(
      title: '下拉刷新',
      home: Scaffold(
        appBar: AppBar(
          title: Text("下拉刷新"),
        ),
        body: RefreshIndicator(
          child: ListView(
            controller: _scrollController,
            children: _buildList(),
          ),
          onRefresh: _refresh,
        ),
      ),
    );
  }

  List<Widget> _buildList(){
    return list.map((city)=>_item(city)).toList();
  }
  _loadData() async{
    await Future.delayed(Duration(microseconds: 200));
    setState(() {
      List<String> newList = List<String>.from(list);
      newList.addAll(list);
      list = newList;
    });
  }

  Future<Null> _refresh() async{
    await Future.delayed(Duration(seconds: 2));
    setState(() {
      list.insert(0, "我是第${++index}下拉刷新加进来的");
    });
    return null;
  }
  Widget _item(String city){
    return Container(
      height: 80,
      margin: EdgeInsets.only(bottom: 5),
      alignment: Alignment.center,
      decoration: BoxDecoration(color: Colors.blue),
      child: Text(
        city,
        style: TextStyle(color: Colors.white,fontSize: 20),
      ),
    );
  }
}

 

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值