无法从Firestore数据库加载分段控件TableView中的数据

时间:2019-09-25 06:25:41

标签: swift firebase uitableview google-cloud-firestore uisegmentedcontrol

我正在尝试通过从Firestore数据库获取数据来填充带分段控件的表视图,但是由于某种原因,我无法这样做,因此我尝试了一个在线的示例,该示例具有预设数据,但是在这里正在从Firestore数据库中检索数据。

它也没有给出任何运行时错误,只是不加载数据。下面是该代码的视图控制器的屏幕截图。请协助

enter image description here

class FirstSegementViewController: UIViewController {

    @IBOutlet var segmentControl:UISegmentedControl!

    @IBOutlet var tableView: UITableView!

    var s1Post:[s1] = []
    var s2Post:[s2] = []


    override func viewDidLoad() {
        super.viewDidLoad()

        // Do any additional setup after loading the view.
        retrieveAllPosts()
    }


    func retrieveAllPosts(){
        let postsRef = Firestore.firestore().collection("posts").limit(to: 50)

        postsRef.getDocuments { (snapshot, error) in

            if let error = error {

                print(error.localizedDescription)

            } else {

                if let snapshot = snapshot {

                    for document in snapshot.documents {


                        let data = document.data()
                        //self.postKey = document.documentID
                        let username = data["post_author_username"] as? String ?? ""
                        let postTitle = data["postTitle"] as? String ?? ""
                        let postcategory = data["postcategory"] as? String ?? ""
                        let postContent = data["postContent"] as? String ?? ""
                        let postAuthorProfilePicUrl = data["post_user_profile_pic_url"] as? String ?? ""
                        let postAuthorSpinnerC = data["post_author_spinnerC"] as? String


                        let newSourse = s1(_documentId: document.documentID, _username: username, _postTitle: postTitle, _postcategory: postcategory, _postContent: postContent, _postuserprofileImagUrl: postAuthorProfilePicUrl, _postAuthorSpinncerC: postAuthorSpinnerC)

                        self.s1Post.append(newSourse)
                        // print(self.postKey)
                    }
                    self.tableView.reloadData()
                }
            }
        }
    }




    @IBAction func indexChanged(_ sender: UISegmentedControl) {
          switch segmentControl.selectedSegmentIndex
         {
         case 0:
            retrieveAllPosts()
         // label1.text = "First Segment Selected"
         case 1:

            retrieveAllPosts()
         // label1.text = "Second Segment Selected"
         default:
         break
         }

        //self.tableView.reloadData()
    }

    /*
     // MARK: - Navigation

     // In a storyboard-based application, you will often want to do a little preparation before navigation
     override func prepare(for segue: UIStoryboardSegue, sender: Any?) {
     // Get the new view controller using segue.destination.
     // Pass the selected object to the new view controller.
     }
     */



    /*
    // MARK: - Navigation

    // In a storyboard-based application, you will often want to do a little preparation before navigation
    override func prepare(for segue: UIStoryboardSegue, sender: Any?) {
        // Get the new view controller using segue.destination.
        // Pass the selected object to the new view controller.
    }
    */

}


extension FirstSegementViewController: UITableViewDelegate, UITableViewDataSource{

    func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
        var value = 0
        switch segmentControl.selectedSegmentIndex{
        case 0:
            value = s1Post.count
            break
        case 1:
            value = s2Post.count
            break
        default:
            break
        }
        return value
    }

    func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {
        let cell = tableView.dequeueReusableCell(withIdentifier: "MyCell", for: indexPath) as! MyWsPostCell
        switch segmentControl.selectedSegmentIndex{
        case 0:
            cell.s11 = s1Post[indexPath.row]
            break
        case 1:
            cell.s21 = s2Post[indexPath.row]
            break

        default:
            break
        }
        return cell
    }


}

1 个答案:

答案 0 :(得分:0)

您似乎仅在为self.s1Post设置值。