【问题标题】:how to pass data between two pages in flutter using bottom navigation bar如何使用底部导航栏在两个页面之间传递数据
【发布时间】:2021-09-15 20:35:11
【问题描述】:

我是 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),
    );
  }
}

【问题讨论】:

    标签: firebase flutter flutter-bottomnavigation


    【解决方案1】:

    您无法在初始化程序中访问实例成员 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
    

    【讨论】:

    • 写完这几行代码后,我得到了堆栈溢出错误
    • 在 cmets 中发布错误信息
    • 在构建 IconButton(Icon, padding: E​​dgeInsets.all(8.0), dependencies: [_LocalizationsScope-[GlobalKey#72baa], _InheritedTheme]) 时引发了以下 StackOverflowError: Stack Overflow
    • 相关的导致错误的小部件是: IconButton file:///D:/flutter/chat_app/lib/screens/home_screen.dart:59:11 抛出异常时,这是堆栈: #0 _createTables. (dart:core/uri.dart:3872:53) #1 new _GrowableList.generate (dart:core-patch/growable_array.dart:133:28) #2 _createTables (dart:core /uri.dart:3872:16) #3 _scannerTables (dart:core/uri.dart:3751:40) #4 _scannerTables (dart:core/uri.dart)
    • 这个错误是由home_screen中的IconButton引起的,而不是CustomBottomNavigationBar。在错误发生之前您是否点击了任何按钮?您能否在 homeScreen 中打印 widget.user 以确保它已正确传递。
    猜你喜欢
    • 2019-06-12
    • 1970-01-01
    • 2011-01-11
    • 2022-11-29
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2020-09-24
    • 2013-11-24
    相关资源
    最近更新 更多