Almacené isQuick
valor desde el backend. Usé sqflite para almacenar en caché. Siempre el resultado esfalse
En mi página de panel,
bool isQuick;
@override
void initState() {
isQuick = false;
timer1 = Timer.periodic(Duration(seconds: 5), (Timer t) {
checkQuick(_url, tokens, isQuick);
});
timer = Timer.periodic(Duration(seconds: 10), (Timer t) {
Future datas = HelperDatabase1().displayGetUserPreference();
datas.then((v) => {
data = v,
print('new data ${data[0].data}'),
data[0].data == 0 ? this.isQuick == false : this.isQuick == true,
print(this.isQuick)
});
submitRequestSave(_url, tokens);
});
}
en mi método de construcción,
@override
Widget build(BuildContext context) {
return WillPopScope(
onWillPop: () async => false,
child: Scaffold(
backgroundColor: Colors.white,
appBar: AssetRegisterAppBar(context),
body: makeBody(litems, litems_icon, _url, this.isQuick, isOffline,
statusbarHeight, context),
));
}
checkQuick método,
Future checkQuick(String url, String token, bool isQuick) async {
print('quick $isQuick');
bool newQuick;
final response = await http.get(
'$url/nativeapi/v1.0/User/GetUserPreference',
headers: {'Authorization': 'Bearer $token'},
);
final jsonResponse = json.decode(response.body);
GetUserPreference model = GetUserPreference.fromJson(jsonResponse);
var data = GetUserPreference(data: model.data);
print(data.data);
if (data.data == 0) {
newQuick = false;
} else {
newQuick = true;
}
print('new quick $newQuick');
if (isQuick != newQuick) {
int newData;
if (newQuick) {
newData = 1;
} else {
newData = 0;
}
await HelperDatabase1().updateGetUserPreference(1, newData);
}
}
Su isQuick estaba null
en el momento en que se llamó para crear su página. Asígnele un valor predeterminado:
@override
void initState() {
isQuick = false; // or true
Future datas = HelperDatabase1().displayGetUserPreference();
datas.then((v) =>
{data = v, data[0].data == 0 ? this.isQuick == false : this.isQuick == true});
}
ACTUALIZAR
Para abordar el problema principal, debe mostrar los widgets alternativos (como CircularProgressIndicator
) cuando el valor de isQuick
todavía se está cargando (o aún null
).
return WillPopScope(
onWillPop: () async => false,
child: Scaffold(
backgroundColor: Colors.white,
appBar: AssetRegisterAppBar(context),
body: isQuick == null
? CircularProgressIndicator()
: makeBody(litems, litems_icon, _url, this.isQuick, isOffline, statusbarHeight, context),
),
);
Este artículo se recopila de Internet, indique la fuente cuando se vuelva a imprimir.
En caso de infracción, por favor [email protected] Eliminar
Déjame decir algunas palabras