开发者问题收集

Flutter Web Firestore 错误:预期类型为“((Object?)=> Object)?”的值,但得到的类型为“(Object)=> Object?”

2021-03-01
2254

我简化了重现此错误的代码。它适用于 Android 模拟器,但在 Web 上运行时从 Firestore 获取集合数据时会失败。

错误消息:

Error: [cloud_firestore/unknown] Expected a value of type '((Object?) => Object)?', but got one of type '(Object) => Object?'
    at Object.throw_ [as throw] (http://localhost:58066/dart_sdk.js:5028:11)
    at collection_reference_web.CollectionReferenceWeb.new.get (http://localhost:58066/packages/cloud_firestore_web/src/write_batch_web.dart.lib.js:370:23)
    at get.next (<anonymous>)
    at http://localhost:58066/dart_sdk.js:37206:33
    at _RootZone.runUnary (http://localhost:58066/dart_sdk.js:37077:59)
    at _FutureListener.thenAwait.handleValue (http://localhost:58066/dart_sdk.js:32333:29)
    at handleValueCallback (http://localhost:58066/dart_sdk.js:32860:49)
    at Function._propagateToListeners (http://localhost:58066/dart_sdk.js:32898:17)
    at _Future.new.[_completeWithValue] (http://localhost:58066/dart_sdk.js:32746:23)
    at async._AsyncCallbackEntry.new.callback (http://localhost:58066/dart_sdk.js:32767:35)
    at Object._microtaskLoop (http://localhost:58066/dart_sdk.js:37329:13)
    at _startMicrotaskLoop (http://localhost:58066/dart_sdk.js:37335:13)
    at http://localhost:58066/dart_sdk.js:33106:9


Doctor summary (to see all details, run flutter doctor -v):
[√] Flutter (Channel beta, 1.26.0-17.6.pre, on Microsoft Windows [Version 10.0.18363.1379], locale ru-RU)
[√] Android toolchain - develop for Android devices (Android SDK version 30.0.0)
[√] Chrome - develop for the web
[√] Android Studio (version 4.1.0)
[√] IntelliJ IDEA Ultimate Edition (version 2020.1)
[√] VS Code (version 1.53.2)
[√] Connected device (2 available)

main.dart:(MyApp() 只是一个空页面)

import 'package:cloud_firestore/cloud_firestore.dart';
import 'package:flutter/material.dart';
import 'package:firebase_core/firebase_core.dart';
import 'package:firebase_auth/firebase_auth.dart';

List<String> departments = List.empty(growable: true);

void main() async{
  WidgetsFlutterBinding.ensureInitialized();
  await Firebase.initializeApp();
  await FirebaseAuth.instance.signInWithEmailAndPassword(email: "[email protected]", password: "111111");
  CollectionReference departmentsRef = FirebaseFirestore.instance.collection("Departments");
  QuerySnapshot qsDepartments = await departmentsRef.get(); //HERE I GET AN ERROR
  qsDepartments.docs.forEach((element) {
    Map<String, dynamic>? map = element.data();
    print(map!['name']);
    departments.add(map['name']);
  });
  runApp(MyApp());
}

web/index.html:

<!DOCTYPE html>
<html>
<head>
  <base href="/">

  <meta charset="UTF-8">
  <meta content="IE=Edge" http-equiv="X-UA-Compatible">
  <meta name="description" content="A new Flutter application.">

  <!-- iOS meta tags & icons -->
  <meta name="apple-mobile-web-app-capable" content="yes">
  <meta name="apple-mobile-web-app-status-bar-style" content="black">
  <meta name="apple-mobile-web-app-title" content="test_web_firestore">
  <link rel="apple-touch-icon" href="icons/Icon-192.png">

  <!-- Favicon -->
  <link rel="icon" type="image/png" href="favicon.png"/>

  <title>test_web_firestore</title>
  <link rel="manifest" href="manifest.json">
</head>
<body>
  <script>
    if ('serviceWorker' in navigator) {
      window.addEventListener('flutter-first-frame', function () {
        navigator.serviceWorker.register('flutter_service_worker.js');
      });
    }
  </script>
  <script src="main.dart.js" type="application/javascript"></script>
  <!-- The core Firebase JS SDK is always required and must be listed first -->
  <script src="https://www.gstatic.com/firebasejs/8.2.9/firebase-app.js"></script>
  <script src="https://www.gstatic.com/firebasejs/8.2.9/firebase-auth.js"></script>
  <script src="https://www.gstatic.com/firebasejs/8.2.9/firebase-firestore.js"></script>

  <script>
  // Your web app's Firebase configuration
  var firebaseConfig = {
    apiKey: "AIzaSyA6BARqtxEwWAvYG9etXXz9iknq6PviJCU",
    authDomain: "testwebfirestore.firebaseapp.com",
    projectId: "testwebfirestore",
    storageBucket: "testwebfirestore.appspot.com",
    messagingSenderId: "604806481003",
    appId: "1:604806481003:web:9fe9c74feaceb71ee91d2e"
  };
  // Initialize Firebase
  firebase.initializeApp(firebaseConfig);
</script>
</body>
</html>

pubspec.yaml:

name: test_web_firestore
description: A new Flutter application.

publish_to: 'none' # Remove this line if you wish to publish to pub.dev

version: 1.0.0+1

environment:
  sdk: ">=2.12.0-0 <3.0.0"

dependencies:
  flutter:
    sdk: flutter
  firebase_core: ^0.8.0-1.0.nullsafety.1
  firebase_auth: ^0.21.0-1.1.nullsafety.1
  cloud_firestore: ^0.17.0-1.0.nullsafety.0



  # The following adds the Cupertino Icons font to your application.
  # Use with the CupertinoIcons class for iOS style icons.
  cupertino_icons: ^1.0.2

dev_dependencies:
  flutter_test:
    sdk: flutter

# The following section is specific to Flutter.
flutter:

  # The following line ensures that the Material Icons font is
  # included with your application, so that you can use the icons in
  # the material Icons class.
  uses-material-design: true

使用 flutter run --no-sound-null-safety 运行时,我收到另一个错误:

Error: [cloud_firestore/unknown] NoSuchMethodError: invalid member on null: 'includeMetadataChanges'
    at Object.throw_ [as throw] (http://localhost:62031/dart_sdk.js:5331:11)
    at collection_reference_web.CollectionReferenceWeb.new.get (http://localhost:62031/packages/cloud_firestore_web/src/write_batch_web.dart.lib.js:370:23)
    at get.next (<anonymous>)
    at http://localhost:62031/dart_sdk.js:39029:33
    at _RootZone.runUnary (http://localhost:62031/dart_sdk.js:38886:58)
    at _FutureListener.thenAwait.handleValue (http://localhost:62031/dart_sdk.js:33872:29)
    at handleValueCallback (http://localhost:62031/dart_sdk.js:34432:49)
    at Function._propagateToListeners (http://localhost:62031/dart_sdk.js:34470:17)
    at _Future.new.[_completeWithValue] (http://localhost:62031/dart_sdk.js:34312:23)
    at async._AsyncCallbackEntry.new.callback (http://localhost:62031/dart_sdk.js:34335:35)
    at Object._microtaskLoop (http://localhost:62031/dart_sdk.js:39173:13)
    at _startMicrotaskLoop (http://localhost:62031/dart_sdk.js:39179:13)
    at http://localhost:62031/dart_sdk.js:34686:9
2个回答

我认为这是 Firebase 中的一个错误。在他们修复此问题之前,您可以尝试将 firebase_core/firebase_core_web/lib/src/interop/utils/utils.dart 的本地副本从:

dynamic dartify(
  Object? jsObject, [
  Object Function(Object? object)? customDartify,
])

更改为

dynamic dartify(
  Object? jsObject, [
  Object? Function(Object object)? customDartify,
])

您还需要从 cloud_firestore/cloud_firestore_web/lib/src/interop/utils/utils.dart 中删除 as Object Function(Object?)?)

至少这解决了我的问题(目前)。

broken.eggshell
2021-03-08

谢谢,John Michael Gelilio。将 firebase-fire.js 版本从 8.2.9 降级到 8.0.1 后,我可以运行没有空安全性的应用程序。

<script src="https://www.gstatic.com/firebasejs/8.0.1/firebase-firestore.js"></script>

使用空安全性运行时出现相同错误,但目前这不是问题

RomaAlf
2021-03-04