web-dev-qa-db-ja.com

Flutter-NoSuchMethodError:nullでゲッター 'focusScopeNode'が呼び出されました

ある画面から別の画面にListを渡そうとすると、次のエラーが発生します。データはasync関数から渡されています。データベースから取得したデータに基づいて、別の画面を開く必要があります。言及された答え here は私にはうまくいきませんでした。ここにエラーがあります。

: [ERROR:flutter/lib/ui/ui_Dart_state.cc(157)] Unhandled Exception: NoSuchMethodError: The 
getter 'focusScopeNode' was called on null.
E/flutter (26425): Receiver: null    
E/flutter (26425): Tried calling: focusScopeNode
E/flutter (26425): #0      Object.noSuchMethod (Dart:core-patch/object_patch.Dart:53:5)
E/flutter (26425): #1      Route.didPush.<anonymous closure> (package:flutter/src/widgets/navigator.Dart:139:17)    

非同期関数のコード

 Navigator.Push(context, MaterialPageRoute(builder: (context) {
    return ParentHome(childList);

親ホーム画面

      class ParentHome extends StatefulWidget {
  List childDataList;

  ParentHome(this.childDataList);

  @override
  State<StatefulWidget> createState() {
    return ParentHomeWidget();
    }
   }
class ParentHomeWidget extends State<ParentHome> {
  @override
  Widget build(BuildContext context) {
// TODO: implement build
return MaterialApp(
  home: Scaffold(
    body: Container(
      margin: EdgeInsets.all(5),
      child: ListView.builder(
          itemCount: widget.childDataList.length,
          itemBuilder: (BuildContext context, int index) => ListTile(
                title: Text(widget.childDataList[index]['title']),
              )),
    ),
      ),
    );
  }
}

これに関するヘルプは見つかりません。これを理解するのを手伝ってください。私はまだFlutterの初心者です。ありがとう

フラッタードクター出力

Flutter(チャネル安定、v1.12.13 + hotfix.5、Linuxの場合、ロケールen_US.UTF-8)
•/home/jamshaid/Documents/flutter_linux_v1.9.1+hotfix.4-stable/flutterにあるFlutterバージョン1.12.13 + hotfix.5
•フレームワークリビジョン27321ebbad(6週間前)、2019-12-10 18:15:01 -0800•エンジンリビジョン2994f7e1e6
•Dartバージョン2.7.0
完全な同期機能

Future<void> requestLogin(String userType) async {
/*
final response =
    await http.get('http://10.0.2.2/php_to_flutter/login_validation.php');*/
String databaseAddress = "";

switch (userType) {
  case "Student":
    databaseAddress = AppUtils.studentLoginLink;
    break;
  case "Parent":
    databaseAddress = AppUtils.parentLoginLink;

    break;
  case "Teacher":
    databaseAddress = AppUtils.teacherLoginLink;
    break;
}

    final response = await http
    .post(databaseAddress, body: {"email": email, "password": password});
String responseBody = response.body;

if (response.statusCode == 200) {
  switch (userType) {
    case "Student":
      print("Registration # $responseBody");
      break;
    case "Parent":
      List childList = responseBody.split(",");
      //child list needs to be separated by :
      /*Navigator.of(context).Push(
          MaterialPageRoute(builder: (context) => ParentHome(childList)));
      */
      Navigator.Push(context, MaterialPageRoute(builder: (context) {
        return ParentHome(childList);
      }));
      //Navigator.pop(context);

      print("Child List= $responseBody");
      break;
    case "Teacher":
      print("Teacher id= $responseBody");
      break;
  }
  form_key.currentState.reset();
  //dismissing progress dialog
  Navigator.pop(context);
  Toast.show("Login Successful", context,
      duration: Toast.LENGTH_SHORT, gravity: Toast.CENTER);
 } else {
   Navigator.pop(context);
  print(databaseAddress);

  Toast.show("Error: " + response.statusCode.toString(), context,
      duration: Toast.LENGTH_SHORT, gravity: Toast.CENTER);

  print('error' + response.body);
  print(response.statusCode);
 }
 }

非同期呼び出し元コード非同期関数がonPressedRaisedButtonで呼び出されています。

Widget studentLoginButton() {
    return RaisedButton(
      onPressed: () {
        if (form_key.currentState.validate()) {
          form_key.currentState.save();
          //  pr.show();
          AppUtils.showProgressDialog(context, "Loggin in...");
          requestLogin("Student");
          form_key.currentState.reset();

          //pr.dismiss();
        }

        // form_key.currentState.reset();
      },
      child: Text('S Login'),
      color: Colors.lightBlue,
    );
  }
1
Jamshaid

スイッチブロックの後に別のNavigator.pop(context);があります。いずれのケースも一致しない場合に戻ることを意図していた場合は、そのケースも削除するか、defaultケースを設定してみてください。

switch (userType) {
    case "Student":
      print("Registration # $responseBody");
      break;
    case "Parent":
      List childList = responseBody.split(",");
      //child list needs to be separated by :
      /*Navigator.of(context).Push(
          MaterialPageRoute(builder: (context) => ParentHome(childList)));
      */
      Navigator.Push(context, MaterialPageRoute(builder: (context) {
        return ParentHome(childList);
      }));
      //Navigator.pop(context);

      print("Child List= $responseBody");
      break;
    case "Teacher":
      print("Teacher id= $responseBody");
      break;
  }
  form_key.currentState.reset();
  //dismissing progress dialog
  //Navigator.pop(context);
  Toast.show("Login Successful", context,
      duration: Toast.LENGTH_SHORT, gravity: Toast.CENTER);

または

switch (userType) {
    case "Student":
      print("Registration # $responseBody");
      break;
    case "Parent":
      List childList = responseBody.split(",");
      //child list needs to be separated by :
      /*Navigator.of(context).Push(
          MaterialPageRoute(builder: (context) => ParentHome(childList)));
      */
      Navigator.Push(context, MaterialPageRoute(builder: (context) {
        return ParentHome(childList);
      }));
      //Navigator.pop(context);

      print("Child List= $responseBody");
      break;
    case "Teacher":
      print("Teacher id= $responseBody");
      break;
    default:
      form_key.currentState.reset();
      //dismissing progress dialog
      Navigator.pop(context);
      Toast.show("Login Successful", context,
        duration: Toast.LENGTH_SHORT, gravity: Toast.CENTER);
  }
3
Jacob McGowan