将 Firebase 数据转换为 Dart Pojo 类的正确方法

本文介绍了如何将从 Firebase 读取的数据转换为 Dart 中的 Pojo (Plain Old Java Object) 类,解决 `CartItem.fromJson` 方法在转换 Firebase 数据时出现空值问题的方案。通过示例代码展示了 `fromJson` 工厂方法的正确写法,并强调了数据类型匹配的重要性,确保数据能够成功地从 Firebase 转换为 Dart 对象。

理解 Firebase 数据与 Dart 对象转换

从 Firebase 读取数据时,数据通常以 Map 的形式存在。 要将其转换为 Dart 对象,我们需要创建一个 fromJson 工厂方法,该方法接收这个 Map 作为输入,并返回一个对象实例。 关键在于确保 Map 中的键与 Dart 类的属性名匹配,并且数据类型正确。

解决空值问题

从问题描述来看,company 属性在转换后变成了 null。 这通常是由于以下几个原因造成的:

  1. Firebase 中的 company 字段本身就是 null。
  2. fromJson 方法中对 company 字段的处理不正确。
  3. _product 变量包含嵌套的对象,而不是扁平化的数据。

首先,你需要检查 Firebase 中的数据,确认 company 字段是否存在且不为 null。 如果字段存在且有值,那么问题可能出在 fromJson 方法上。

正确的 fromJson 工厂方法写法

以下是一个更健壮的 fromJson 工厂方法示例,它可以处理空值和类型转换:

class CartItem {
  String? id;
  String? title;
  int? quantity;
  double? price;
  String? company;
  String? model;

  CartItem({
    this.id,
    this.title,
    this.quantity,
    this.price,
    this.company,
    this.model,
  });

  factory CartItem.fromJson(Map json) {
    return CartItem(
      id: json['id'] as String?,
      title: json['title'] as String?,
      quantity: json['quantity'] as int?,
      price: (json['price'] as num?)?.toDouble(), // 处理 price 为 null 的情况并转换为 double
      company: json['company'] as String?,
      model: json['model'] as String?,
    );
  }
}

代码解释:

  • 类型转换: 使用 as String? 和 as int? 进行类型转换,允许字段为 null。
  • 空值处理: 对于 price 字段,使用了 (json['price'] as num?)?.toDouble()。这表示如果 json['price'] 为 null,则整个表达式的结果也为 null,避免了空指针异常。如果 json['price'] 存在,则将其转换为 double。
  • num? 的使用: 使用 num? 作为中间类型,可以同时兼容 int 和 double 类型,然后再使用 toDouble() 转换为 double。这使得代码更灵活,可以处理 Firebase 中可能出现的不同数字类型。

确保数据结构正确

在将 Firebase 数据传递给 fromJson 方法之前,请确保 _product 变量包含的是扁平化的数据,而不是嵌套的对象。 检查 docSnapshot.data() 的输出,确认其结构是否符合预期。

如果 _product 包含嵌套的对象,你需要先提取出所需的数据,然后再传递给 fromJson 方法。

示例代码

以下是一个完整的示例,展示了如何从 Firebase 读取数据并将其转换为 CartItem 对象:

import 'package:cloud_firestore/cloud_firestore.dart';

class CartItem {
  String? id;
  String? title;
  int? quantity;
  double? price;
  String? company;
  String? model;

  CartItem({
    this.id,
    this.title,
    this.quantity,
    this.price,
    this.company,
    this.model,
  });

  factory CartItem.fromJson(Map json) {
    return CartItem(
      id: json['id'] as String?,
      title: json['title'] as String?,
      quantity: json['quantity'] as int?,
      price: (json['price'] as num?)?.toDouble(),
      company: json['company'] as String?,
      model: json['model'] as String?,
    );
  }
}

void main() async {
  // 初始化 Firebase (确保已配置 Firebase)
  WidgetsFlutterBinding.ensureInitialized();
  await Firebase.initializeApp();

  CollectionReference collectionRef = FirebaseFirestore.instance.collection('your_collection'); // 替换为你的集合名称

  collectionRef.get().then(
    (querySnapshot) {
      print("All Orders");
      for (var docSnapshot in querySnapshot.docs) {
        var _product = docSnapshot.data();
        CartItem cartItem = CartItem.fromJson(_product);
        print(cartItem.company); // 打印 company 属性
      }
    },
    onError: (e) => print("Error completing: $e"),
  );
}

注意事项:

  • 确保你已经正确配置了 Firebase,并且已经添加了 cloud_firestore 依赖。
  • 将 'your_collection' 替换为你的 Firebase 集合名称。
  • 在 main() 函数中,你需要使用 WidgetsFlutterBinding.ensureInitialized() 和 Firebase.initializeApp() 来初始化 Firebase。

总结

将 Firebase 数据转换为 Dart 对象需要仔细处理数据类型和空值。 通过使用正确的 fromJson 工厂方法,并确保数据结构正确,你可以成功地将 Firebase 数据转换为 Dart 对象,并在你的应用程序中使用它们。 记住,在调试过程中,始终检查 Firebase 中的数据,以确认其结构和内容是否符合预期。