如何将特定的ListTile变量传递给onTap的新页面路由?

时间:2019-02-06 12:33:10

标签: firebase dart flutter google-cloud-firestore

我的代码构建了一个ListTiles的ListView,每个ListTile从Cloud Firestore数据库中获取数据。

当我激活ListTile的onTap时,我想路由到新页面并将该磁贴的特定数据传递到新页面。

我在其上构建列表视图的页面上已毫无问题地将变量传递给了,但是我无法在该页面上使用相同的方法来工作。

我对扑扑和飞镖还挺陌生的。我的第一个假设是,可能需要有状态的小部件才能完成此任务?但是我不确定如何实现。

import 'package:flutter/material.dart';

import 'package:menu/screens/menu/detail.dart';

import 'package:cloud_firestore/cloud_firestore.dart';
import 'package:firebase_storage/firebase_storage.dart';

class Menu extends StatelessWidget {
    final String barcode;

  // receive data from the FirstScreen as a parameter
  Menu({Key key, @required this.barcode}) : super(key: key);

  Widget _buildListItem(BuildContext context, DocumentSnapshot document) {
    return ListTile(
      leading: Icon(Icons.fastfood),
      title: Text(document['item'] ?? '*name*'),
      subtitle: Text( document['description'] ?? '*description*'),
      isThreeLine: true,
      onTap: (){
        Navigator.push(
            context,
            MaterialPageRoute(
            builder: (context) => Detail(),
        ),);
        },
    );
  }

  @override
  Widget build(BuildContext context) {
    return Scaffold(
      appBar: AppBar(
        title: Text('Menu'),
      ),
      body: StreamBuilder(
          stream: Firestore.instance.collection(barcode).snapshots(),
          builder: (context, snapshot) {
            if (!snapshot.hasData) return const Text('loading...');
            return ListView.builder(
              itemExtent: 80.0,
              itemCount: snapshot.data.documents.length,
              itemBuilder: (context, index) =>
                  _buildListItem(context, snapshot.data.documents[index]),
            );
          }),
    );
  }
}

1 个答案:

答案 0 :(得分:1)

document作为参数传递给Detail

    Navigator.push(
        context,
        MaterialPageRoute(
        builder: (context) => Detail(document), // <-- document instance
    ),);

Detail小部件当然需要使用document作为参数:

class Detail extends ... {
  Detail(this.document);
  final DocumentSnapshot document;
}

https://flutter.io/docs/cookbook/navigation/passing-data

中所述