В настоящее время я обращаюсь к указанному 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());
}
}))));
}
}