flutter 命名路由传值[2020-06-01]

2020年6月1日 命名路由传参方法

命名路由设置(无需任何改动)

  return MaterialApp(
      home: Tabs(),
      routes: {
        '/form':(context)=>FormPage(),
        '/search':(context)=>SearchPage(),
      }
    );

路由跳转设置(设置传递的参数)

   Navigator.pushNamed(context, '/form',arguments:{'title':'这是获取到的参数'});

页面取值

import 'package:flutter/material.dart';

class FormPage extends StatelessWidget {
  String _title = '表单'; //这里这个变量可以不申明,但是为了方便传值

  @override
  Widget build(BuildContext context) {
    Map arguments = ModalRoute.of(context).settings.arguments; //关键代码,取值
    if (arguments != null) {
      //判断是否传递
      _title = arguments['title'] ?? this._title; //进行赋值
    }
    return Scaffold(
        appBar: AppBar(
          title: Text(this._title), //显示传递过来的值
        ),
        body:  Text('这是表单页面')
    );
  }
}
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

友情链接更多精彩内容