拍摄Firebase数据快照并存储数据

时间:2017-02-11 04:40:09

标签: ios json parsing firebase firebase-realtime-database

我有以下JSON Firebase数据库:

{ "fruits": {
        "apple": {
            "name": "Gala",
            "url": "//s-media-cache-ak0.pinimg.com/564x/3e/b1/e7/3eb1e756d66856975d6e43ebb879200a.jpg",
            "fruitArray": [1, 2]
        },
       "orange": {
             "name": "Tangerine",
             "url": "//userscontent2.emaze.com/images/0ba588c8-42d9-45e9-a843-d19e5720515a/e430f9a827f139e9f99f2826175dd0a9.jpg",
             "fruitArray": []
        } 
    }
}

以下Fruit类:

class Fruit {
     var name: String
     var url: String
     var fruitArray: [Int]
     var ref: FIRDatabaseReference?

    init(name: String, url: String, fruitArray: [Int]) {
        self.name = name
        self.url = url
        self.fruitArray = fruitArray
        self.ref = nil
    }

    init(snapshot: FIRDataSnapshot) {
        let snapshotValue = snapshot.value as! [String: Any]
        name = snapshotValue["name"] as! String
        url = snapshotValue["url"] as! String
        if snapshotValue["fruitArray"] == nil {
            fruitArray = [0]
        } else {
            fruitArray = snapshotValue["fruitArray"] as! [Int]
        }
        ref = snapshot.ref
    }

    func toAnyObject() -> Any {
        return [
            "name": name,
            "url": url,
            "fruitArray": fruitArray
        ]
    }

以下的FruitTableViewController代码:

class FruitTableViewController: UITableViewController {

    // MARK: Properties
    var fruits: [Fruit] = []

    override func viewDidLoad() {
        super.viewDidLoad()

        let ref = FIRDatabase.database().reference(withPath: "fruits")

        ref.queryOrdered(byChild: "name").observe(.value, with: { snapshot in
            var addedFruits: [Fruit] = []

            for fruit in snapshot.children {
                let newFruit = Fruit(snapshot: fruit as! FIRDataSnapshot)
                addedFruit.append(newFruit)
            }

            self.fruits = addedFruits

            self.tableView.reloadData()
        })
    }

    override func didReceiveMemoryWarning() {
        super.didReceiveMemoryWarning()
    }

    override func numberOfSections(in tableView: UITableView) -> Int {
        return 1
    }

    override func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
        return fruits.count
    }


    override func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {
        let cell = tableView.dequeueReusableCell(withIdentifier: "cell", for: indexPath) as? FruitTableViewCell 

        let fruit = fruits[indexPath.row]
        let imgURL = NSURL(string: fruit.url)

        if imgURL != nil {
            let data = NSData(contentsOf: (imgURL as? URL)!)
            cell.icon.image = UIImage(data: data as! Data)
        }

        cell.nameLabel.text = fruit.name

        return cell
    }

由于某种原因,Firebase快照无法正常工作。我几乎没有运气就试过了。

这不是一个TableViewCell问题(我认为),因为我检查了FruitViewCell和Storyboard,一切都井然有序。我的预感是它与我将URL更改为字符串以及数组的方式有关。我已经将这个确切的代码用于不同的iOS项目并且它有效但两个项目之间的区别在于,这个项目在JSON中有一个数组和链接,而另一个没有。

我已经看到有其他方法可以拍摄快照,但我将在整个应用程序中使用水果数据,因此我更容易拥有一个水果对象,但如果有人在建议另一种拍摄快照的方法。任何帮助表示赞赏!

1 个答案:

答案 0 :(得分:1)

首先使用此代码更改您的viewDidLoad,因为根本不需要添加根据

override func viewDidLoad() {
    super.viewDidLoad()

    let ref = FIRDatabase.database().reference().child("fruits")

    ref.observe(.value, with: { snapshot in
        if snapshot.exists() {
            for fruit in snapshot.children {
            let newFruit = Fruit(snapshot: fruit as! FIRDataSnapshot)
            self.fruits.append(newFruit)
        }
        self.tableView.reloadData()
        }

    })
}
  

检查firebase规则是否已正确设置读取和写入。我认为这是一个问题,因为可能是您没有设置该规则。