首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何在颤振中使用flutter_bloc自动刷新前一页(首页)

如何在颤振中使用flutter_bloc自动刷新前一页(首页)
EN

Stack Overflow用户
提问于 2020-02-12 19:03:22
回答 3查看 2.6K关注 0票数 1

场景

有两个页面,第一个页面是HomePage,它在flutter_bloc包的帮助下自动获取api数据。在主页(第一页)中还有一个按钮,在这个代码Navigator.push(context, MaterialPageRoute(builder: (BuildContext context) => SettingsPage()));的帮助下,它会转到第二页(设置页面)。在第二页中,底部有3个无线电按钮和一个按钮(按钮名为Save)。当我单击“保存”按钮时,它会在以下代码Navigator.pop(context);的帮助下返回到主页

问题

当我选择任何一个无线电按钮并单击底部的按钮时,如何刷新或重建主页并再次获取api数据。

EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2020-02-12 19:12:50

可以将主页单元的实例传递给“设置”页单元,然后在按“保存”或更改“设置”中的选项时,在“主页”框中触发一个事件,该事件将获取更新的数据并在主页单元输出流中发出结果。

票数 1
EN

Stack Overflow用户

发布于 2020-12-03 11:20:17

代码语言:javascript
复制
// Sample code 

'import 'package:flutter/material.dart';

void main() => runApp(new MyApp());

class MyApp extends StatelessWidget {
  @override
  Widget build(BuildContext context) {
    return new MaterialApp(
      title: 'Flutter Demo',
      theme: new ThemeData(
        primarySwatch: Colors.blue,
      ),
      home: new MyHomePage(),
    );
  }
}

EdgeInsets globalMargin =
const EdgeInsets.symmetric(horizontal: 20.0, vertical: 20.0);
TextStyle textStyle = const TextStyle(
  fontSize: 100.0,
  color: Colors.black,
);

class MyHomePage extends StatefulWidget {
  @override
  _MyHomePageState createState() => _MyHomePageState();
}

class _MyHomePageState extends State<MyHomePage> {
  int number = 0;

  @override
  Widget build(BuildContext context) {
    return new Scaffold(
      appBar: new AppBar(
        title: new Text('SO Help'),
      ),
      body: new Column(
        children: <Widget>[
          new Text(
            number.toString(),
            style: textStyle,
          ),
          new GridView.count(
            crossAxisCount: 2,
            shrinkWrap: true,
            scrollDirection: Axis.vertical,
            children: <Widget>[
              new InkResponse(
                child: new Container(
                    margin: globalMargin,
                    color: Colors.green,
                    child: new Center(
                      child: new Text(
                        "+",
                        style: textStyle,
                      ),
                    )),
                onTap: () {
                  setState(() {
                    number = number + 1;
                  });
                },
              ),
              new Sub(this),
            ],
          ),
        ],
      ),
      floatingActionButton: new FloatingActionButton(
        onPressed: () {
          setState(() {});
        },
        child: new Icon(Icons.update),
      ),
    );
  }
}

class Sub extends StatelessWidget {

  _MyHomePageState parent;

  Sub(this.parent);

  @override
  Widget build(BuildContext context) {
    return new InkResponse(
      child: new Container(
          margin: globalMargin,
          color: Colors.red,
          child: new Center(
            child: new Text(
              "-",
              style: textStyle,
            ),
          )),
      onTap: () {
        this.parent.setState(() {
          this.parent.number --;
        });
      },
    );
  }
}
票数 0
EN

Stack Overflow用户

发布于 2021-03-09 11:03:53

在第一页的onPressed函数中使用此代码

代码语言:javascript
复制
Navigator.of(context).push(new MaterialPageRoute(builder: (_)=>new PageTwo()),)
    .then((val)=>val?_getRequests():null),

_getRequest的值更改为API调用,将第二页更改为下一页。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/60195248

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档