Как обновить API данных страницы, чтобы динамически получать данные в flutter

#flutter #dart #flutter-layout

Вопрос:

Я использовал индикатор обновления, чтобы обновить данные страницы, но он не работает

Это мой код!! помогите мне решить проблему с обновлением данных

 import 'dart:async';
import 'package:apitest3/services/api_manager.dart';
import 'package:flutter/cupertino.dart';
import 'package:flutter/material.dart';
import 'models/statusinfo.dart';
import 'package:flutter/services.dart';


class TestPage extends StatefulWidget {
  const TestPage({Key? key}) : super(key: key);
  @override
  _TestPageState createState() => _TestPageState();
}


class _TestPageState extends State<TestPage> {
 
 late Future<Status> _status;
  
 

  final GlobalKey<RefreshIndicatorState> _refreshIndicatorkey =
  new GlobalKey<RefreshIndicatorState>();

  @override
  void initState() {
    _status = API_Manager().getStatus();
    super.initState();
    WidgetsBinding.instance?.addPostFrameCallback(
            (_) => _refreshIndicatorkey.currentState?.show());
  }


  @override
  Widget build(BuildContext context) {
    final key = new GlobalKey<ScaffoldState>();

    return Scaffold(
      
      body: SafeArea(
        child: RefreshIndicator(
          key: keyStatus,
          onRefresh: () => _status,
          child: Container(
            decoration: BoxDecoration(
                gradient: LinearGradient(
                    begin: Alignment.topCenter,
                    end: Alignment.bottomCenter,
                    colors: [Colors.purple, Colors.blue])),
            padding: EdgeInsets.all(4),
            child: FutureBuilder<Status>(
              future: _status,
              builder: (context, snapshot) {
                if (snapshot.hasData) {
                  return ListView.builder(
                      padding: EdgeInsets.all(4),
                      itemCount: 1,
                      itemBuilder: (context, index) {
                        var result = snapshot.data!.result.syncInfo;
                        return Flexible(
                          child: Card(
                            elevation: 20,
                            shape: RoundedRectangleBorder(
                              borderRadius: BorderRadius.circular(10),
                            ),
                            color: Colors.indigo.shade900,
                            child: Column(
                              mainAxisAlignment: MainAxisAlignment.center,
                              children: <Widget>[
                                Padding(
                                  padding: const EdgeInsets.all(8.0),
                                  child: Row(
                                    children: [
                                      Container(
                                          child: Text(
                                            "Latest Block Hash ",
                                            style: TextStyle(
                                                fontSize: 15,
                                                color: Colors.white),
                                          )),
                                    ],
                                  ),
                                ),
                                Padding(
                                  padding: const EdgeInsets.all(8.0),
                                  child: Row(
                                    children: [
                                      RaisedButton.icon(
                                          color: Colors.blueAccent,
                                          onPressed: () {
                                            Clipboard.setData(ClipboardData(
                                                text: result.latestBlockHash));
                                            key.currentState!
                                                .showSnackBar(new SnackBar(
                                                 backgroundColor:Colors.amberAccent,
                                                  content: new Text(
                                                "Copied to Latest Block Hash!!",
                                                style: TextStyle(
                                                    color: Colors.red),
                                              ),
                                            ));
                                          },
                                          icon: Icon(
                                            Icons.copy,
                                            color: Colors.white,
                                            size: 15,
                                          ),
                                          label: Text(
                                            "${result.latestBlockHash}",
                                            style: TextStyle(
                                                fontSize: 7.1,
                                                color: Colors.white),
                                            overflow: TextOverflow.ellipsis,
                                            maxLines: 1,
                                          )),
                                         ),
                                       ),
                                     ),
                                   );
                                }
                               }
                               ),
                                ),
                               
                                Card(
                                  color: Colors.blueAccent,
                                  child: Padding(
                                    padding: const EdgeInsets.all(6.0),
                                    child: Container(
                                      height: 20,
                                      child: Row(
                                        children: [
                                          Text(
                                            " ${result.latestBlockTime
                                                .toString()}",
                                            style: TextStyle(
                                                fontSize: 10,
                                                color: Colors.white),
                                          ),
                                        ],
                                ),
                              ],
                            ),
                          ),
                        );
                      });
                } else
                  return Center(child: CircularProgressIndicator()
                    //CupertinoActivityIndicator()
                  );
              },
            ),
          ),
        ),
      ),
    );
  }
}
 

Я не знаю, в чем я допустил ошибку в этом коде для функции обновления
И все поэтому я пытаюсь использовать метод корневой навигации, но он открывает больше страниц на одной странице, поэтому один раз попробуйте закрыть страницу, чтобы закрыть несколько страниц,
поэтому постарайтесь помочь мне правильно обновить страницу.

Ответ №1:

Вам необходимо обновить состояние после обновления при onRefresh обратном вызове. В настоящее время вы просто присваиваете его Future переменной.

Это простой способ сделать это.

 RefreshIndicator(
   onRefresh: () { setState((){
         // Update your data here
       }); },
   child: ...
  )
 

Комментарии:

1. Приведите мне несколько примеров полного кода или ссылок для установки «setState» в трепете.