Flutter-setState在HTTP响应代码中不起作用

时间:2019-07-05 05:28:33

标签: flutter dart

我有一个简单的页面,可以从服务器获取数据并解析响应。 我有两个对用户可见的小部件,一个是_loadingWidget()小部件,另一个是errorWidget()小部件。

我添加了一些打印语句,以显示执行代码的位置。一切正常,但是setState的{​​{1}}无法正常工作。 我在这里做错了什么?

errorWidget()

1 个答案:

答案 0 :(得分:1)

我通过设置bool来解决它:

import 'package:flutter/material.dart';
import 'dart:io';
import 'dart:convert';
import 'package:http/http.dart' as http;
import 'package:validators/validators.dart';

import '../strings.dart';

class FetchDataPage extends StatefulWidget {
  final String text;
  FetchDataPage({Key key, @required this.text}) : super(key: key);

  @override
  _FetchDataState createState() => _FetchDataState();
}

class _FetchDataState extends State<FetchDataPage> {
  String _productUrl;
  bool showError = false;

  @override
  Widget build(BuildContext context) {
    _productUrl = widget.text;
    if (_productUrl != null) {
      checkPrice(_productUrl);
    }
    return Scaffold(
      body: Container(padding: EdgeInsets.all(20.0), child: pageWidget()),
    );
  }

  Widget pageWidget() {
    if (showError == false) {
      return Column(
        mainAxisAlignment: MainAxisAlignment.center,
        crossAxisAlignment: CrossAxisAlignment.center,
        children: <Widget>[
          Center(
            child: CircularProgressIndicator(
              backgroundColor: Colors.transparent,
              valueColor: AlwaysStoppedAnimation<Color>(Colors.blueGrey),
            ),
          ),
          SizedBox(height: 20.0),
          Text(
            "Checking Price...",
            style: TextStyle(
              color: Colors.blueGrey,
              fontSize: 20.0,
              fontWeight: FontWeight.w500,
            ),
          ),
        ],
      );
    } else {
      return Column(
        mainAxisAlignment: MainAxisAlignment.center,
        crossAxisAlignment: CrossAxisAlignment.center,
        children: <Widget>[
          Center(
            child: Icon(
              Icons.sentiment_dissatisfied,
              color: Colors.red,
              size: 60.0,
            ),
          ),
          SizedBox(height: 20.0),
          Center(
            child: Text(
              "Product not found in database.\nPlease try again later.",
              textAlign: TextAlign.center,
              style: TextStyle(
                color: Colors.blueGrey,
                fontSize: 17.0,
                fontWeight: FontWeight.w500,
              ),
            ),
          ),
        ],
      );
    }
  }

  void checkPrice(String productUrl) {
    bool isUrl = isURL(productUrl, requireProtocol: true, requireTld: true);
    if (!isUrl) {
      RegExp regExp = new RegExp(r"((\w+:\/\/\S+)|(\w+[\.:]\w+\S+))[^\s,\.]");
      setState(() {
        productUrl = regExp.stringMatch(productUrl).toString();
      });
    }
    var response = getLatestPrice(productUrl);
    response.then((response) {
      if (response.statusCode == 200) {
        var loginData = json.decode(response.body);
        bool status = loginData["status"];
        if (status) {
          print(loginData["productUrl"]);
        } else {
          setState(() {
            showError = true;
          });
        }
      } else {
        setState(() {
          showError = true;
        });
      }
    });
  }
}

Future<http.Response> getLatestPrice(productUrl) async {
  var url = Strings.baseUrl + 'api/checkPrice';
  var response = await http.post(url, body: {
    'product_url': productUrl,
  }, headers: {
    HttpHeaders.authorizationHeader:
        "Basic " + base64Encode(utf8.encode('username:password'))
  });
  return response;
}