技术胖Flutter第四季-22页面跳转并返回数据

视频地址:

 

https://www.bilibili.com/video/av35800108/?p=23

 博客地址:

https://jspang.com/post/flutter4.html#toc-3f5

 

主要学习子页面返回数据给父页面

 

 

 

下划线很一般定义内部的方法

 

 

snackBar去接收

 

XiaoJieJie类的创建

XiaoJieJie这个类就相当于我们的子页面

快捷键stless快速生成类:

快速生成可以谁用安卓studio里面的 Live Template:

 

 

navigator.pop方法,返回数据就是启用第二个参数

 

 

运行效果

 

点击按钮回调到首页 下面并snackbar显示出来 子页面传回来的信息

 

 

 

 

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(),
      ),
    );
  }
}
class RouteButton extends StatelessWidget {
  @override
  Widget build(BuildContext context) {
    return RaisedButton(
      onPressed: (){
        _navigateToXiaoJieJie(context);
      },
      child: Text('去找小 姐姐'),
    );
  }

  _navigateToXiaoJieJie(BuildContext context) async{
    final result= await Navigator.push(
      context, 
      MaterialPageRoute(builder: (context)=>XiaoJieJie())
      );

      Scaffold.of(context).showSnackBar(SnackBar(content:Text('$result')));
  }
}
class XiaoJieJie 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,'大长腿小姐姐:1511111111');
            },),
             RaisedButton(
               child: Text('小蛮腰小姐姐'),
               onPressed: (){
               Navigator.pop(context,'小蛮腰小姐姐:152222222');
               },),
          ],
        ),
      ),
    );
  }
}
完整代码

 

转载于:https://www.cnblogs.com/wangjunwei/p/10571151.html

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值