Я читал другие вопросы и ответы о переполнении стека об этой проблеме, но, похоже, это проблема tabBarController, о которой я ничего не нашел.
У меня есть tabBarController с 3 вкладками. tab1 — это место, где я успешно отправляю информацию в Firebase. В tab2 у меня есть tableView, который успешно читает данные из tab1.
В tab2 мой слушатель находится в поле зренияWillAppear. Я удаляю прослушиватель в viewDidDisappear (я также пробовал viewWillDisappear), и где-то здесь возникает проблема.
override func viewDidDisappear(animated: Bool) {
self.sneakersRef!.removeAllObservers()
//When I tried using a handle in viewWillAppear and then using the handle to remove the observer it didn't work here either
//sneakersRef!.removeObserverWithHandle(self.handle)
}
Как только я переключаюсь с tab2 на любую другую вкладку, во второй раз я возвращаюсь к tab2, данные таблицы удваиваются, затем, если я снова переключаю вкладки и возвращаюсь, они утраиваются и т. д. Я попытался установить прослушиватель внутри viewDidLoad, который предотвращает дублирование данных таблицы, когда Я переключаю вкладки, но когда я отправляю новую информацию с вкладки 1, информация никогда не обновляется на вкладке 2.
Согласно документам Firebase и почти всему остальному, что я читал в stackoverflow/google, прослушиватель должен быть установлен в viewWillAppear и удален в viewDidDisappear.
Любые идеи о том, как предотвратить дублирование моих данных всякий раз, когда я переключаюсь между вкладками?
вкладка1
import UIKit
import Firebase
import FirebaseAuth
import FirebaseDatabase
class TabOneController: UIViewController{
var ref:FIRDatabaseReference!
@IBOutlet weak var sneakerNameTextField: UITextField!
override func viewDidLoad() {
super.viewDidLoad()
self.ref = FIRDatabase.database().reference()
}
@IBAction func sendButton(sender: UIButton) {
let dict = ["sneakerName":self.sneakerNameTextField.text!]
let usersRef = self.ref.child("users")
let sneakersRef = usersRef.child("sneakers").childByAutoID()
sneakersRef?.updateChildValues(dict, withCompletionBlock: {(error, user) in
if error != nil{
print("\n\(error?.localizedDescription)")
}
})
}
}
вкладка2
import UIKit
import Firebase
import FirebaseAuth
import FirebaseDatabase
class TabTwoController: UITableViewController{
@IBOutlet weak var tableView: UITableView!
var handle: Uint!//If you read the comments I tried using this but nahhh didn't help
var ref: FIRDatabaseReference!
var sneakersRef: FIRDatabaseReference?
var sneakerArray = [String]()
override func viewDidLoad() {
super.viewDidLoad()
self.ref = FIRDatabase.database().reference()
}
override func viewWillAppear(animated: Bool) {
super.viewWillAppear(animated)
let usersRef = self.ref.child("users")
//Listener
self.sneakersRef = usersRef.child("sneakers")
//I tried using the handle
//---self.handle = self.sneakersRef!.observeEventType(.ChildAdded...
self.sneakersRef!.observeEventType(.ChildAdded, withBlock: {(snapshot) in
if let dict = snapshot.value as? [String:AnyObject]{
let sneakerName = dict["sneakerName"] as? String
self.sneakerArray.append(sneakerName)
dispatch_async(dispatch_get_main_queue(), {
self.tableView.reloadData()
})
}
}), withCancelBlock: nil)
}
//I also tried viewWillDisappear
override func viewDidDisappear(animated: Bool) {
self.sneakersRef!.removeAllObservers()
//When I tried using the handle to remove the observer it didn't work either
//---sneakersRef!.removeObserverWithHandle(self.handle)
}
func tableView(tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
return self.sneakerArray.count
}
func tableView(tableView: UITableView, cellForRowAtIndexPath indexPath: NSIndexPath) -> UITableViewCell {
let cell = self.tableView.dequeueReusableCellWithIdentifier("sneakerCell", forIndexPath: indexPath)
cell.textLabel?.text = sneakerArray[indexPath.row]
return cell
}
}
таб3 ничего не делает. Я просто использую его как альтернативную вкладку для переключения туда и обратно с помощью