如何不使用MaterialPageRoute传递参数函数setState?

时间:2020-02-27 20:42:46

标签: flutter dart flutter-layout

我有更新状态的问题。我需要将带有setState的函数传递到小部件中,但是我不知道如何做。问题是我需要传递一个静态函数,并且在其中不能执行setState。我必须修复哪些选项?

我的代码

class NavigationBar extends StatefulWidget {
  @override
  State<StatefulWidget> createState() {
    return _NavigationBarState();
  }
}

class _NavigationBarState extends State<NavigationBar> {
  bool showMusicTab = false;
  bool openMusicTab = false;
  int index = 4;
  final List<Widget> screens = [
    Home(),
    Search(),
    AddPost(),
    Notifications(),
    Profile(showMusicTabAndPlay)
  ];

  @override
  Widget build(BuildContext context) {
    return Scaffold(
      backgroundColor: Colors.black,
      body: screens[index],
      persistentFooterButtons: showMusicTab
          ? <Widget>[
              Container(
                color: Colors.black,
                height: 20,
                width: MediaQuery.of(context).size.width,
                child: ListTile(
                  leading: Icon(Icons.favorite_border, color: Colors.white),
                  title: Center(
                    child: InkWell(
                      onTap: () {},
                      child: Text(
                        'Break my soul',
                        style: TextStyle(
                            color: Colors.white,
                            fontFamily: kRobotoBold,
                            fontWeight: FontWeight.bold),
                      ),
                    ),
                  ),
                  trailing: Icon(
                    Icons.pause_circle_filled,
                    color: Colors.white,
                  ),
                ),
              )
            ]
          : null,
      bottomNavigationBar: BottomNavigationBar(
        currentIndex: index,
        onTap: (int index) {
          setState(() {
            this.index = index;
          });
        },
        type: BottomNavigationBarType.fixed,
        showSelectedLabels: false,
        showUnselectedLabels: false,
        backgroundColor: Colors.black,
        items: [
          new BottomNavigationBarItem(
            icon: new Icon(
              Icons.home,
              color: index == 0 ? Colors.pinkAccent : Colors.white,
            ),
            title: new Text('Home'),
          ),
          new BottomNavigationBarItem(
            icon: new Icon(
              Icons.search,
              color: index == 1 ? Colors.pinkAccent : Colors.white,
            ),
            title: new Text('Search'),
          ),
          new BottomNavigationBarItem(
            icon: new Icon(
              Icons.add_circle,
              color: index == 2 ? Colors.pinkAccent : Colors.white,
            ),
            title: new Text('Add post'),
          ),
          new BottomNavigationBarItem(
            icon: new Icon(
              Icons.notifications,
              color: index == 3 ? Colors.pinkAccent : Colors.white,
            ),
            title: new Text('Notifications'),
          ),
          new BottomNavigationBarItem(
              icon: Icon(
                Icons.person,
                color: index == 4 ? Colors.pinkAccent : Colors.white,
              ),
              title: Text('Profile'))
        ],
      ),
    );
  }

  static void showMusicTabAndPlay() {
    setState(() {
      showMusicTab = true;
    });
  }
}

1 个答案:

答案 0 :(得分:0)

您的问题是,您是在第一次创建窗口小部件时尝试通过直接在字段声明中为其分配对象screens来填充List

class _NavigationBarState extends State<NavigationBar> {
  final List<Widget> screens = [
    Home(),
    Search(),
    AddPost(),
    Notifications(),
    Profile(showMusicTabAndPlay)
  ];

  ...
}

像这样填充对象时,只能使用静态字段和方法来填充它。对于showMusicTabAndPlay来说,这是一个问题,因为它调用setState,这是一个实例方法,不能从静态方法中调用。

相反,您应该在构造函数或screens方法(建议使用后者)中填充initState

class _NavigationBarState extends State<NavigationBar> {
  List<Widget> screens;

  @override
  void initState() {
    super.initState();
    screens = [
      Home(),
      Search(),
      AddPost(),
      Notifications(),
      Profile(showMusicTabAndPlay)
    ];
  }

  ...
}

有了这个,您现在可以将showMusicTabAndPlay用作实例方法而不是静态方法,并且错误将消失。