zoukankan      html  css  js  c++  java
  • Flutter页面跳转返回数据

    Dart中的异步请求和等待和ES6中的方法很像,直接使用async...await就可以实现。

    核心代码:

    _navigateToAddress(BuildContext context) async{ //async是启用异步方法
    
        final result = await Navigator.push(//等待
            context,
            MaterialPageRoute(builder: (context)=> Address())
        );
    
        Scaffold.of(context).showSnackBar(SnackBar(content:Text('$result')));
      }

    示例:

    import 'package:flutter/material.dart';
    
    void main(){
      runApp(MaterialApp(
          title:'页面跳转返回数据',
          home:FirstPage()
      ));
    }
    
    class FirstPage extends StatelessWidget {
      @override
      Widget build(BuildContext context) {
        return Scaffold(
            appBar:AppBar(title:Text("商品列表")),
            body:Center(
              child: RouteButton(),
            )
        );
      }
    }
    
    //跳转的Button
    class RouteButton extends StatelessWidget {
      @override
      Widget build(BuildContext context) {
        return RaisedButton(
          onPressed:(){
            _navigateToAddress(context);
          },
          child: Text('选择地址'),
        );
      }
    
      _navigateToAddress(BuildContext context) async{ //async是启用异步方法
    
        final result = await Navigator.push(//等待
            context,
            MaterialPageRoute(builder: (context)=> Address())
        );
    
        Scaffold.of(context).showSnackBar(SnackBar(content:Text('$result')));
      }
    }
    
    class Address extends StatelessWidget {
      @override
      Widget build(BuildContext context) {
        return Scaffold(
          appBar:AppBar(
              title:Text('地址列表')
          ),
          body:Center(
              child:Column(
                children: <Widget>[
                  RaisedButton(
                    child: Text('地址一'),
                    onPressed: (){
                      Navigator.pop(context,'地址一:北京');
                    },
                  ) ,
                  RaisedButton(
                    child: Text('地址二'),
                    onPressed: (){
                      Navigator.pop(context,'地址二:上海');
                    },
                  ) ,
                ],
              )
          ) ,
        );
      }
    }
  • 相关阅读:
    pandas(六):pandas对excel进行读写
    当方法类bean无法注入时
    js 替换css属性
    select既可以输入也可以下拉框选择
    Java 容器详解
    前端页面获取URL拼接的参数值
    web前端工程师需要掌握的技能
    小程序云开发图片上传存储
    小程序云开发删除‘存储’的图片或文件
    小程序云开发对数据库增删改查相关操作
  • 原文地址:https://www.cnblogs.com/loaderman/p/11250889.html
Copyright © 2011-2022 走看看