标签栏中的tableview无法重新加载

时间:2018-06-25 15:03:25

标签: ios swift uitableview

我的RestaurantApp中有一个带有各种选项卡的TabBar,当我单击addToCart并转到CartViewContorller时,添加的项目没有显示,我必须重新启动App才能看到那里的项目。我在这里看到过类似的问题,但对该问题有各种答案,但是对于我来说,所有解决方案似乎都不起作用,我真的不知道怎么了。以下是我想在每次加载tableview时重新加载tableview的CartViewContorller代码。谢谢大家的帮助

import UIKit
import Alamofire
import os.log

class CartViewController: UITableViewController {

    var cartData = [CartResponse.Cart]()

    override func viewDidLoad() {
        super.viewDidLoad()

        cart()

        tableView.delegate = self
        tableView.dataSource = self

        let nib = UINib(nibName: "viewCartCell", bundle: nil)
        tableView.register(nib, forCellReuseIdentifier: "cartCustomCell")


        let footerView = UIView()
        footerView.backgroundColor = UIColor.red
        footerView.frame = CGRect(x: 0, y: 0, width: view.frame.width, height: 60)
        tableView.tableFooterView = footerView

    }


    override func viewDidAppear(_ animated: Bool) {
        super.viewWillAppear(animated)

       self.tableView.reloadData()
    }


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

    override func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {
        guard let cell: CartTableViewCell = self.tableView.dequeueReusableCell(withIdentifier: "cartCustomCell", for: indexPath) as? CartTableViewCell else {
            os_log("Dequeue cell isn't an instance of CustomTableCell", log: .default, type: .debug)
            fatalError()

        }

        cell.recipeNameLbl?.text = cartData[indexPath.row].recipeName
        cell.restaurantNameLbl?.text = cartData[indexPath.row].restaurantName
        cell.addtionalNoteLbl?.text = cartData[indexPath.row].additionalNote
        cell.quantityLbl?.text = cartData[indexPath.row].recipeQuantity
        cell.totalLbl?.text = cartData[indexPath.row].recipePrice
        cell.totalCostLbl?.text = cartData[indexPath.row].totalCost

        return cell
    }

    override func tableView(_ tableView: UITableView, heightForRowAt indexPath: IndexPath) -> CGFloat {
        return 100
    }

    override func tableView(_ tableView: UITableView, commit editingStyle: UITableViewCellEditingStyle, forRowAt indexPath: IndexPath) {

        guard editingStyle == .delete else {return}

        //getting userId from defaults
        let CartId = cartData[indexPath.row].cartId
        let cartId = CartId

        //creating parameters for the post request
        let parameters: Parameters=[
            "cartId":Int(cartId)
        ]

        //Constant that holds the URL for web service
        let URL_SELECT_FROM_CART = "http://localhost:8888/restaurant/deleteFromCart.php?"

        Alamofire.request(URL_SELECT_FROM_CART, method: .post, parameters: parameters).responseJSON {
            response in
            //printing response
            print(response)
        }

        cartData.remove(at: indexPath.row)
        tableView.deleteRows(at: [indexPath], with: .automatic)

    }

    //Fetching from Cart Method
    func cart(){

        //getting userId from defaults
        let defaultValues = UserDefaults.standard
        let userId = defaultValues.string(forKey: "userid")

        //creating parameters for the post request
        let parameters: Parameters=[
            "userId":Int(userId!)!
        ]

        //Constant that holds the URL for web service
        let URL_SELECT_FROM_CART = "http://localhost:8888/restaurant/cart.php?"

        Alamofire.request(URL_SELECT_FROM_CART, method: .post, parameters: parameters).responseJSON {
            (response) in            

            let result = response.data

            do{
                let decoder = JSONDecoder()
                let downloadedCart = try decoder.decode(CartResponse.self, from: result!)
                self.cartData = downloadedCart.cartItem

                DispatchQueue.main.async {
                    self.tableView.reloadData()
                }

            }catch {
                print(error)
            }
        }.resume()
    }

}

2 个答案:

答案 0 :(得分:0)

您可以使用:

import UserNotifications NotificationCenter.default.post(name: NSNotification.Name(rawValue: "loadCart"), object: nil)

在此answer

中查看更多

答案 1 :(得分:0)

您必须在viewWillAppear中调用cart()此方法,而不是调用viewDidload

 override func viewWillAppear(_ animated: Bool) {
    self.cart()
}