reloadData()不更新单元格标签

时间:2017-02-08 17:28:45

标签: ios swift uitableview core-data

在我的应用程序中,我有一个标签,告知用户缺少一些设置: enter image description here

设置于:

override func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {
    let service = (fetchedResultsController?.object(at: indexPath))! as Service
    let cell = tableView.dequeueReusableCell(withIdentifier: cellId, for: indexPath) as! OfferedServiceCell
    cell.setupDataCell(service: service)
    if service.employee?.count == 0   || service.price?.price == nil || service.price?.slotDuration == nil {
        cell.infoLabel.text = "attention: you need to complete this service set up!"
    }
    let lpGestureRecognizer: UILongPressGestureRecognizer = UILongPressGestureRecognizer(target: self, action: #selector(didLongPressCell(gr:)))
    cell.addGestureRecognizer(lpGestureRecognizer)
    return cell
}

用户可以在另一个tableViewController中添加价格和员工证明该服务,并且当所需的所有信息都保存在核心数据中时,标签应该消失。问题是只有在我重新加载viewController时,标签红色警告才会消失。

这就是我所做的事情:

  1. 由于我使用的是fetchedResultsController,我实现了这个方法:

    func controllerDidChangeContent(_ controller: NSFetchedResultsController<NSFetchRequestResult>) {
        DispatchQueue.main.async {
            self.tableView.reloadData()
        }
    }
    

    一旦我更改了核心数据,就会调用该方法,但警告仍然存在(除非重新加载TableViewController)。我还尝试在self.tableView.layoutIfNeeded()中添加infoLabel.layoutIfNeeded()OfferedServiceCell

  2. 在我添加价格和员工的TableViewController被解雇时发布通知:

     NotificationCenter.default.addObserver(self, selector: #selector(reloadAllData), name: NSNotification.Name(rawValue: "priceListModified"), object: nil)
    
  3. reloadAllData中的

    我甚至试图再次致电performFetch

    func reloadAllData(){
         DispatchQueue.main.async {
                    do {
                        try self.fetchedResultsController?.performFetch()
    
                    } catch {
                        fatalError("Failed to initialize FetchedResultsController: \(error)")
                   }
    
            self.tableView.reloadData()
            self.tableView.layoutIfNeeded()
            }
    }
    

    我不知道还能做些什么。谢谢你的建议。

    -----更新---问题解决了:

    正如Chris Trahey的回答正确指出的那样,我最终将代码设置为我自定义单元格,并在不需要时明确隐藏它:

    func setupDataCell(service:Service){
        self.service =  service
        if service.service_description != nil {
            serviceName.text = service.service_description
        }
    
        if service.employee?.count == 0   || service.price?.price == nil || service.price?.slotDuration == nil {
            if service.selected == 0 {
            infoLabel.text = "Drag service to Service Offered to start using it"
            }else{
            infoLabel.text = "attention: you need to complete this service set up!"
            }
        }else{
            infoLabel.isHidden = true
        }
    }
    

    我使用prepareForReuse将标签设置为nil。 (仍然不确定这一点,但它没有工作)

    override func prepareForReuse() {
        super.prepareForReuse()
        infoLabel.text = nil
    
    }
    

1 个答案:

答案 0 :(得分:1)

我怀疑在不需要标签的情况下,单元设置例程没有清除标签。因此,标签在重复使用周期中存活。我会做两个:

  • setupDataCell不应该只在需要时设置红色标签属性,它还应该明确隐藏它不属于它。
  • 在自定义单元格类上实现prepareForReuse并清除标签