Загрузка данных из Firebase в Xcode UITableView - PullRequest
0 голосов
/ 19 февраля 2019

Привет, ребята. Я пытаюсь загрузить определенные элементы (активность, заголовок, широта и долгота) из моей базы данных Firebase.При создании моментального снимка данных и попытке выбрать один элемент Title возникает ошибка, в которой говорится, что nil был найден.

Это структура JSON

{
  "location" : {
   "-LY55OLlInZ0HLepGZWp" : {
      "Activity" : "Legs",
      "Description" : "Anainssnsj skak\nHsians\nAhah",
      "Difficulty" : "Beginner",
      "Lat" : "",
      "Long" : "",
      "Rating" : "3",
      "Title" : "Busan",
      "id" : "-LY55OLjAA3Cbcvaf8SG"
    },
    "-LY55SN53euLPN9UxoM5" : {
      "Activity" : "Board",
      "Description" : "Stktwks",
      "Difficulty" : "Beginner",
      "Lat" : "lat:-35.14202623881991",
      "Long" : "long:138.54526039212942",
      "Rating" : "3",
      "Title" : "Jettei",
      "id" : "-LY55SN40TARVvysV8fi"
    },
  },

. Здесь приведен код, который сохраняетинформация в Firebase:

  func saveLocationInformation() {
    let key = refLocation.childByAutoId().key

    guard let title = locationTitle.text  else {return}
    guard let location = geoCoordinate.text  else {return}
    guard let long = geoLong.text else {return}
    guard let description = descriptionText.text  else {return}
    guard let rating = flameNumber.text  else {return}
    guard let difficulty = difficultyRating.text else {return}
    guard let activity = activityLabel.text else {return}


    let lTitle = [
        "id": key,
        "Title": title,
        "Activity": activity,
        "Lat": location,
        "Long": long,
        "Description": description,
        "Rating": rating,
        "Difficulty": difficulty,
    ] as [String:Any]
    let lID = [
        "id": key,
    ] as [String:Any]

    refLocation.childByAutoId().setValue(lTitle)

}

и вот код, который пытается сделать снимок данных и поместить информацию в TableView

import UIKit
import Firebase
class TableViewControllerVC: UITableViewController {


 var locationData = [locationSearch]()

 var ref: DatabaseReference!
 var dataHandle: DatabaseHandle?




 override func viewDidLoad() {

     super.viewDidLoad()

     loadInfo()
 }

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



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



    return cell
}


 func loadInfo() {
    ref = Database.database().reference()
    ref.child("location").observe(.value) { (snapshot: DataSnapshot) in
        if let dict = snapshot.value as? [String: AnyObject] {
            //
            let titleT =  dict["Title"]
            //                let activityA = dict["Activity"] as! String
            //                let loc = locationSearch(titleText: titleT, activityText: activityA)
            //                self.locationData.append(loc)

            print(titleT)
            self.tableView.reloadData()
        }
    }

}




}

1 Ответ

0 голосов
/ 19 февраля 2019

Прямо сейчас ваш наблюдатель выбирает дочерние идентификаторы в качестве значений, а не их словари .

Если вы хотите установить наблюдателя, который ищет всех дочерних элементов и прослушивает дочерних добавок к ветви "location", попробуйте заменить loadInfo() следующим:

func loadInfo() {
    ref = Database.database().reference()

    ref.child("location").observe(.childAdded) { (snapshot: DataSnapshot) in
        // will iterate through each child of "location" branch
        if let dict = snapshot.value as? [String: AnyObject] {
            let titleT =  dict["Title"] as? String

            print(titleT) // will return "Title" branch value
        }
    }

}

Или, если вы хотите использовать значение моментального снимка , как ваш исходный код, используйте вместо этого одно наблюдение за событием, подобное этому, которое получает список дочерних элементов и перебирает их:

func loadInfoOnce() {
    ref = Database.database().reference()

    ref.child("location").observeSingleEvent(of: .value) { (snapshot) in
        // will iterate through each child of "location" branch
        if let locationIds = snapshot.children.allObjects as? [DataSnapshot] {

            for locationId in locationIds {
                let dict = locationId.value as? [String: AnyObject]
                let titleT =  dict["Title"] as? String
                print(titleT) // will return "Title" value for each location id
            }
        }
    }

}
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...