Flutter - NoSuchMethodError: метод получения isNotEmpty был вызван для нулевого значения

Это приложение мирового времени, которое начинается с главного экрана, показывающего местоположение по умолчанию в начале, затем вы можете изменить местоположение, и API покажет вам время в этом новом местоположении. Он работает нормально, но когда я нажимаю кнопку "Назад" на панели "Местоположение", появляется ошибка!!

Вот мой домашний код:

class _HomeState extends State<Home> {
Map data = {};
@override
Widget build(BuildContext context) {
//the argument method is taking data from another route
//I use this 
data = data.isNotEmpty ? data : ModalRoute.of(context).settings.arguments;

//data = ModalRoute.of(context).settings.arguments;

//isDaytime is a bool
String bgImage = data['isDaytime'] ? 'day.png' : 'night.png';
Color bar = data['isDaytime'] ? Colors.blue[300] : Colors.indigo[900]; 

return Scaffold(
  backgroundColor: bar,
  body: SafeArea(
    child: Container(
      width: 415.0,
      decoration: BoxDecoration(
        image: DecorationImage(
          image: AssetImage('assets/$bgImage'),
          fit: BoxFit.cover,
        ),
      ),
      child: Padding(
        padding: const EdgeInsets.fromLTRB(0, 120.0, 0, 0),
        child: Column(
          children: <Widget>[
            FlatButton.icon(
              onPressed: () async {
                dynamic result =
                    await Navigator.pushNamed(context, '/location');
                setState(() {
                  data = result;
                });
              },
              icon: Icon(
                Icons.edit_location,
                color: Colors.grey[200],
                size: 25.0,
              ),
              label: Text(
                'Edit Location',
                style: TextStyle(
                  color: Colors.grey[200],
                  fontSize: 20.0,
                ),
              ),
            ),
            RichText(
              text: TextSpan(
                text: data['location'],
                style: TextStyle(
                  color: Colors.white,
                  fontSize: 40.0,
                ),
              ),
            ),
            RichText(
              text: TextSpan(
                text: data['time'],
                style: TextStyle(
                  color: Colors.white,
                  fontSize: 70.0,
                ),
              ),
            ),
          ],
        ),
      ),
    ),
  ),
);

}}

а вот код экрана моего местоположения:

class location extends StatefulWidget {
  @override
 _locationState createState() => _locationState();
}

  class _locationState extends State<location> {
 List<Worldtime> locations = [
   Worldtime(url: 'Africa/Cairo', location: 'Cairo', flag: 'egypt.png'),
   Worldtime(url: 'Europe/London', location: 'London', flag: 'uk.png'),
  Worldtime(url: 'America/New_York', location: 'New york', flag: 'usa.png'),
  Worldtime(url: 'Europe/Berlin', location: 'Berlin', flag: 'germany.png')
  ];

  void updateTime(index) async {
Worldtime instance = locations[index];
await instance.getTime();

Navigator.pop(context, {
  'location' : instance.location,
  'flag' : instance.flag,
  'time' : instance.time,
  'isDaytime' : instance.isDaytime,
});
}

 @override
Widget build(BuildContext context) {
return Scaffold(
  body: ListView.builder(
      itemCount: locations.length,
      itemBuilder: (context, index) {
        return Padding(
          padding:
              const EdgeInsets.symmetric(vertical: 1.0, horizontal: 4.0),
          child: Card(
            child: ListTile(
              title: Text(locations[index].location),
              leading: CircleAvatar(
                backgroundImage:
                    AssetImage('assets/${locations[index].flag}'),
              ),
              onTap: () {
                updateTime(index);
              },
            ),
          ),
        );
      }),
  appBar: AppBar(
    title: Text('Choose Location'),
    backgroundColor: Colors.grey[800],
    elevation: 0,
  ),
);
 }
 }

1 ответ

Решение

Ты делаешь

data = await Navigator.pushNamed(context, '/location')

который при нажатии кнопки возврата выводит

await Navigator.pushNamed(context, '/location')

равно нулю, поэтому данные будут нулевыми.

Оберните эшафот на странице местоположения с помощью WillPopScope виджет и вывести маршрут с желаемыми данными.

Другие вопросы по тегам