Flutter: как загрузить файл Json на локальный компьютер и затем получить к нему доступ - PullRequest
0 голосов
/ 26 мая 2020

В настоящее время я обращаюсь к указанному c JSON файлу country.json по DefaultAssetBundle следующим образом:

Future<List<Country>> getCountryFromJson(BuildContext context) async {
    String jsonString =
        await DefaultAssetBundle.of(context).loadString('assets/country.json');
    List<dynamic> raw = jsonDecode(jsonString);
    return raw.map((e) => Country.fromJson(e)).toList();
  }

Однако я хочу обновить новый json файл (то же имя) загрузив его в FirebaseStorage , затем каждый раз, когда приложение открывается, оно будет загружать новый файл через get http и обращаться к нему позже (приложение по-прежнему обращается к старому файлу, когда загрузка нового файла не завершена)

Итак, я хочу спросить, как сделать следующее:

- Вариант 1: Загрузите новый файл country.json с Http ссылку и перезапишите его на старый файл в активах
- Вариант 2. Если он не может помешать активам, загрузите его, где это возможно, в локальное хранилище и установите приоритет доступа к новому файлу над старым файлом в активах

это главный файл:

import 'dart:convert';
import 'dart:core';
import 'package:ask/country.dart';
import 'package:flutter/material.dart';


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

class MyApp extends StatefulWidget {
  @override
  _MyAppState createState() => _MyAppState();
}

class _MyAppState extends State<MyApp> {
  Future<List<Country>> getCountryFromJson(BuildContext context) async {
    String jsonString =
        await DefaultAssetBundle.of(context).loadString('assets/country.json');
    List<dynamic> raw = jsonDecode(jsonString);
    return raw.map((e) => Country.fromJson(e)).toList();
  }

  Widget build(BuildContext context) {
    return new MaterialApp(
        home: Scaffold(
            appBar: AppBar(title: Text('Country')),
            body: Container(
                child: FutureBuilder(
                    future: getCountryFromJson(context),
                    builder: (context, data) {
                      if (data.hasData) {
                        List<Country> countries = data.data;
                        return ListView.builder(
                            itemCount: countries.length,
                            itemBuilder: (context, index) {
                              return Padding(
                                  padding: const EdgeInsets.all(5.0),
                                  child: Column(children: <Widget>[
                                    Text(
                                      countries[index].country,
                                    )
                                  ]));
                            });
                      } else {
                        return Center(child: CircularProgressIndicator());
                      }
                    }))));
  }
}

...