flutter ListView列表和导航传值以及回调

main.dart

import 'package:flutter/material.dart';

void main(){
  return runApp(MyApp());
}

class ProductInfo{
  final String title;
  final String description;
  ProductInfo(this.title,this.description);
}

class MyApp extends StatelessWidget {

  @override
  Widget build(BuildContext context) {
    return MaterialApp(
      title: '导航栏传值',
      home: Scaffold(
        appBar: AppBar(title: Text('导航栏传值'),),
        body: ProductList(
          products: List.generate(20, (i)=>ProductInfo("title$i", "description")),
        ),
      ),
    );
  }
}

class ProductList extends StatelessWidget{
  final List<ProductInfo> products;
  ProductList({Key key, @required this.products}):super(key:key);
  @override
  Widget build(BuildContext context) {
    
    return ListView.builder(
      itemCount: products.length,
      itemBuilder: (context,index){
        return ListTile(
          title: Text(products[index].title),
          //列表被点击
          onTap: (){
            print(products[index].title);
          //   Navigator.push(
          //     context, 
          //     MaterialPageRoute(
          //       builder:(context) => ProductDetail(product: products[index])
          //     ));
          _jumpToDetail(context,index);
          },

        );
      },
    );
  }
  _jumpToDetail(BuildContext context,int index) async{

    final result = await Navigator.push(
      context,
      MaterialPageRoute(
        builder: (context) => ProductDetail(product: products[index])
      )
    );
    //使用showSnackBar显示弹窗
    Scaffold.of(context).showSnackBar(
       SnackBar(
         content: Text(result),
         duration: Duration(seconds: 1),
         )
      );
  }
}

class  ProductDetail extends StatelessWidget {
  final ProductInfo product;
  ProductDetail({Key key, @required this.product}):super(key:key);
  @override
  Widget build(BuildContext context) {
    return Scaffold(
      appBar: AppBar(title: Text(product.title)),
      body: Center(
          child: RaisedButton(
          child: Text("点击返回"),
          onPressed: (){
            Navigator.pop(context,'反向传值result=${product.title}');
          },
        ),
      )
    );
  }
}

重点
1.快速创建模型对象

List.generate(20, (i)=>ProductInfo("title$i", "description"))

2.快速创建ListView列表

ListView.builder(
      itemCount: products.length,
      itemBuilder: (context,index){
        return ListTile(
          title: Text(products[index].title),
          //列表被点击
          onTap: (){
            print(products[index].title);
            Navigator.push(
              context, 
              MaterialPageRoute(
                builder:(context) => ProductDetail(product: products[index])
              ));
          },

        );
      },
    );

3.导航Navigator push

            Navigator.push(
              context, 
              MaterialPageRoute(
                builder:(context) => ProductDetail(product: products[index])
              ));
          },

4.导航pop

    //不含参数
    Navigator.pop(context);
    //包含回调参数
    Navigator.pop(context,'反向传值result=${product.title}');

5.反向传值

    //通过result接收返回值
    final result = await Navigator.push(
      context,
      MaterialPageRoute(
        builder: (context) => ProductDetail(product: products[index])
      )
    );

6.SnackBar显示回调值

    Scaffold.of(context).showSnackBar(
       SnackBar(
         content: Text(result),
         duration: Duration(seconds: 1),
         )
      );

转载于:https://www.cnblogs.com/qqcc1388/p/11376468.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Flutter,下拉列表可以通过使用RefreshIndicator组件来实现。RefreshIndicator是一个可以在用户下拉列表时触发刷新操作的组件。通常,我们会将RefreshIndicator包裹在ListView组件,以便在下拉时触发刷新操作。 下面是一个示例代码,展示了如何在Flutter创建一个带有下拉刷新功能的列表: ```dart RefreshIndicator( onRefresh: _handleRefresh, child: ListView( children: _buildList(), ), ) ``` 在这个示例,_handleRefresh是一个回调函数,用于处理刷新操作。_buildList()函数返回一个包含列表项的列表。 如果你想要在下拉列表时同时控制滚动,你可以使用ListView的controller属性来挂载一个ScrollController控制器。下面是一个示例代码: ```dart RefreshIndicator( onRefresh: _handleRefresh, child: ListView( controller: _scrollController, children: _buildList(), ), ) ``` 在这个示例,_scrollController是一个ScrollController控制器,用于控制列表的滚动。 另外,如果你想要创建一个可展开的下拉列表,你可以使用ExpansionTile组件。下面是一个示例代码: ```dart ExpansionTile( title: Text('专业列表'), leading: Icon(Icons.list), children: <Widget>\[ ListTile( title: Text('title'), subtitle: Text('subtitle'), ), ListTile( title: Text('title'), subtitle: Text('subtitle'), ), ListTile( title: Text('title'), subtitle: Text('subtitle'), ), ListTile( title: Text('title'), subtitle: Text('subtitle'), ), \], ) ``` 在这个示例,ExpansionTile组件包含一个标题和一个图标,当用户点击时,会展开显示子项。子项可以是任意的Widget,这里使用了多个ListTile作为子项。 希望这些示例代码能够帮助你在Flutter创建下拉列表。如果还有其他问题,请随时提问。 #### 引用[.reference_title] - *1* *2* [flutter实现列表下拉刷新上拉加载](https://blog.csdn.net/a646639956/article/details/115336991)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control,239^v3^insert_chatgpt"}} ] [.reference_item] - *3* [flutter两种写下拉列表的方式](https://blog.csdn.net/m0_47265814/article/details/111686265)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值