firebase - 如何使用底部导航栏在flutter中的两个页面之间传递数据

标签 firebase flutter flutter-bottomnavigation

我是 flutter 世界的新手。我正在使用底部导航栏,但我不知道如何将数据从底部导航栏页面传递到主页,因为主页需要 1 个参数。我正在其他页面之间传递数据,但我找不到在底部导航栏和主页之间传递数据的方法。任何帮助将不胜感激 提前致谢

这是我的导航页面代码

import 'package:chat_app/models/user_model.dart';
import 'package:chat_app/screens/call_log_screen.dart';
import 'package:chat_app/screens/chat_screen.dart';
import 'package:chat_app/screens/home_screen.dart';
import 'package:chat_app/screens/search_screen.dart';
import 'package:cloud_firestore/cloud_firestore.dart';
import 'package:firebase_auth/firebase_auth.dart';
import 'package:flutter/cupertino.dart';
import 'package:flutter/material.dart';

class CustomBottomNavigationBar extends StatefulWidget {
  UserModel user;
  CustomBottomNavigationBar(this.user);
  @override
  _CustomBottomNavigationBarState createState() =>
      _CustomBottomNavigationBarState();
}

class _CustomBottomNavigationBarState extends State<CustomBottomNavigationBar> {
  int _selectedIndex = 0;
  late final screens = [
    HomeScreen(widget.user),
    CallLog(),
    CallLog(),
    CallLog(),
  ];

  void onTapped(int index) {
    print(widget.user.name);
    setState(() {
      _selectedIndex = index;
    });
  }

  @override
  Widget build(BuildContext context) {
    return Scaffold(
      body: screens[_selectedIndex],
      bottomNavigationBar: BottomNavigationBar(
        backgroundColor: Colors.black,
        selectedIconTheme: IconThemeData(color: Colors.blue),
        currentIndex: 2,
        items: [
          BottomNavigationBarItem(
            icon: Icon(
              CupertinoIcons.settings,
              color: Colors.grey,
            ),
            label: 'hi',
          ),
          BottomNavigationBarItem(
            icon: Icon(
              CupertinoIcons.home,
              color: Colors.grey,
            ),
            label: 'hi',
          ),
          BottomNavigationBarItem(
            icon: Icon(
              CupertinoIcons.phone,
              color: Colors.grey,
            ),
            label: 'hi',
          ),
          BottomNavigationBarItem(
            icon: Icon(
              CupertinoIcons.chat_bubble_text,
              color: Colors.grey,
            ),
            label: 'hi',
          ),
        ],
        onTap: onTapped,
      ),
    );
  }
}

这是我的主页代码

import 'package:cached_network_image/cached_network_image.dart';
import 'package:chat_app/models/user_model.dart';
import 'package:chat_app/screens/chat_screen.dart';
import 'package:chat_app/screens/search_screen.dart';
import 'package:chat_app/widgets/bottom_navigation_bar.dart';
import 'package:cloud_firestore/cloud_firestore.dart';
import 'package:firebase_auth/firebase_auth.dart';
import 'package:flutter/cupertino.dart';
import 'package:flutter/material.dart';
import 'package:google_sign_in/google_sign_in.dart';
import 'package:intl/intl.dart';

import 'auth_screen.dart';

class HomeScreen extends StatefulWidget {
  UserModel user;
  HomeScreen(this.user);

  @override
  _HomeScreenState createState() => _HomeScreenState();
}

class _HomeScreenState extends State<HomeScreen> with WidgetsBindingObserver {
  @override
  void initState() {
    // TODO: implement initState
    super.initState();
    WidgetsBinding.instance!.addObserver(this);
    setStatus('online');
  }

  void setStatus(String status) async {
    await FirebaseFirestore.instance
        .collection('users')
        .doc(widget.user.uid)
        .update({"userStatus": status});
  }

  @override
  void didChangeAppLifecycleState(AppLifecycleState state) {
    // TODO: implement didChangeAppLifecycleState
    if (state == AppLifecycleState.resumed) {
      //online
      setStatus("online");
    } else {
      //offline
      setStatus('offline');
    }
  }

  @override
  Widget build(BuildContext context) {
    return Scaffold(
      appBar: AppBar(
        title: Text('Home'),
        centerTitle: true,
        backgroundColor: Colors.deepPurple,
        actions: [
          IconButton(
            onPressed: () async {
              await GoogleSignIn().signOut();
              await FirebaseAuth.instance.signOut();
              setStatus('offline');
              Navigator.pushAndRemoveUntil(
                  context,
                  MaterialPageRoute(
                    builder: (context) => AuthScreen(),
                  ),
                  (route) => false);
            },
            icon: Icon(Icons.logout),
          ),
        ],
      ),
      body: StreamBuilder(
        stream: FirebaseFirestore.instance
            .collection('users')
            .doc(widget.user.uid)
            .collection('messages')
            .snapshots(),
        builder: (context, AsyncSnapshot snapshot) {
          if (snapshot.hasData) {
            if (snapshot.data.docs.length < 1) {
              return Center(
                child: Text('No Chat Available!!!'),
              );
            }
            return ListView.builder(
              itemCount: snapshot.data.docs.length,
              itemBuilder: (context, index) {
                var friendId = snapshot.data.docs[index].id;
                var lastMsg = snapshot.data.docs[index]['last_message'];
                var lastMsgTime =
                    snapshot.data.docs[index]['last_message_time'];

                return FutureBuilder(
                  future: FirebaseFirestore.instance
                      .collection('users')
                      .doc(friendId)
                      .get(),
                  builder: (context, AsyncSnapshot asyncSnapShot) {
                    if (asyncSnapShot.hasData) {
                      var friend = asyncSnapShot.data;
                      return ListTile(
                        leading: ClipRRect(
                          borderRadius: BorderRadius.circular(80.0),
                          child: CachedNetworkImage(
                            imageUrl: friend['image'],
                            placeholder: (context, url) =>
                                CircularProgressIndicator(),
                            errorWidget: (context, url, error) =>
                                Icon(Icons.error),
                          ),
                          // child: Image.network(
                          //   friend['image'],
                          // ),
                        ),
                        trailing: Text(
                          DateFormat.jm().format(
                            lastMsgTime.toDate(),
                          ),
                        ),
                        title: Text(
                          friend['name'],
                        ),
                        subtitle: Text(
                          "$lastMsg",
                          style: TextStyle(color: Colors.grey),
                          overflow: TextOverflow.ellipsis,
                        ),
                        onTap: () {
                          Navigator.push(
                            context,
                            MaterialPageRoute(
                              builder: (context) => ChatScreen(
                                currentUser: widget.user,
                                receiverId: friend['uid'],
                                receiverImage: friend['image'],
                                receiverName: friend['name'],
                              ),
                            ),
                          );
                        },
                      );
                    }

                    return LinearProgressIndicator();
                  },
                );
              },
            );
          }
          return Center(
            child: CircularProgressIndicator(),
          );
        },
      ),
      floatingActionButton: FloatingActionButton(
        onPressed: () {
          Navigator.push(
            context,
            MaterialPageRoute(
              builder: (context) => SearchScreen(widget.user),
            ),
          );
          // Navigator.pushAndRemoveUntil(
          //     context,
          //     MaterialPageRoute(
          //       builder: (context) => SearchScreen(widget.user),
          //     ),
          //     (route) => false);
        },
        child: Icon(CupertinoIcons.search),
      ),
      bottomNavigationBar: CustomBottomNavigationBar(widget.user),
    );
  }
}

最佳答案

您无法在初始化程序中访问实例成员widget

试试这个

class _CustomBottomNavigationBarState extends State<CustomBottomNavigationBar> {
  int _selectedIndex = 0;
  late final List screens;

  @override
  void initState() {
    super.initState();

    screens = [
      HomeScreen(widget.user),
      CallLog(),
      CallLog(),
      CallLog(),
    ];
  }
...
// the rest of your code

关于firebase - 如何使用底部导航栏在flutter中的两个页面之间传递数据,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/69199486/

相关文章:

mobile - 更改文本字段的大小和行为

flutter - 如何在Flutter中使用图像图标(来自 Assets )而不是IconData和分页bottomNavigationBar

Firebase 身份验证电子邮件自定义

javascript - 从 firebase 检索信息不起作用, key 不是函数

javascript - 如何使用 Firebase 按时间戳排序?

flutter - Flutter:如何删除BottomNavigationBar的边框?

flutter - 我怎样才能在 flutter 中删除这个底部导航栏上的白色背景

javascript - 从 firebase 函数读取数据

firebase - 使用http或database管理firebase实时数据库引用效率更高?

flutter - 缺少具体实现 'getter Equatable'/props 问题