LoginSignup
2

More than 5 years have passed since last update.

ObjectMapperを使ってFirebaseのリストを扱う

Last updated at Posted at 2018-08-17

リストを定義したオブジェクトの配列にしてcollectionviewとかに使いたいっすよねー
Firebaseのデータはswiftだと型チェックとかkeyがあるかとか確認がめんどくさい。
ObjectMapperを使うとその辺が少し楽になる。

それとFirebaseのデータをObjectMapperを用いてデータ構造を管理する方法を参考にしている。
これのリスト版という感じ。

Mapperを定義

import ObjectMapper

struct Hoge: Mappable {
    var id: String!
    var name: String!

    init?(map: Map) { }

    mutating func mapping(map: Map) {
        id <- map["id"]
        name <- map["name"]
    }
}

extensionでMapperを拡張

import ObjectMapper
import FirebaseDatabase

extension Mapper {
    public func map(snapshot: DataSnapshot) -> N? {
        guard var value = snapshot.value as? [ String: AnyObject ] else { return nil }
        value["id"] = snapshot.key as AnyObject
        guard let object = Mapper<N>().map(JSON: value) else {
            return nil
        }
        return object
    }

    public func mapArray(snapshot: DataSnapshot) -> [N?] {
        return snapshot.children.allObjects.map({object in
            guard let snapshot = object as? DataSnapshot else {
                return nil
            }
            return Mapper<N>().map(snapshot: snapshot)
        })
    }
}

リストのデータを取得

ref.child("hoges").observeSingleEvent(of: DataEventType.value, with: { snapshot in
    print(Mapper<Hoge>().mapArray(snapshot: snapshot))
})

まーnullチェックとかは結局どっかでしないといけないけどねー

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
2