在连续点击后首次点击并抓取之前的值后,后端不会更新

时间:2016-03-09 00:05:51

标签: ios arrays swift boolean firebase

我正在使用Swift中的“待办事项”应用程序并使用Firebase作为我的后端。

在第一次点击我的复选框以表示任务已完成时,UI更新并且变量应该变为true(显示复选标记)但firebase和该项目的bool值的本地实例不会更新为假。在第二次点击后,UI继续具有正常功能(复选标记消失);但是firebase和本地实例都更新为true。之后的点击是相反的(True表示没有复选标记,false表示复选标记)。当我在Xcode中停止模拟器并重新运行时,加载的值和UI是正确的。直到我尝试点击复选标记,我再次得到错误的功能。 Firebase仅在第二次点按并更改UI后更新。我只包含了与复选框相关的代码。我认为问题发生在doneHit函数中,但我不确定它为什么会发生。

请帮忙。如果有更简单的方法,那也会有所帮助。

protocol TaskCellDelegate {
    func doneHit(cell : TaskCell)
}

class TaskCell : UITableViewCell {

    var delegate : TaskCellDelegate?

    @IBOutlet weak var label: UILabel!
    @IBOutlet weak var checkBox: CheckBox!
    @IBOutlet weak var detailLabel: UILabel!


    override func awakeFromNib() {
        super.awakeFromNib()
        checkBox.addTarget(self, action: "buttonClicked:", forControlEvents: UIControlEvents.TouchUpInside)
    }


    func buttonClicked(sender:UIButton) {
        delegate?.doneHit(self)

    }

}


class CheckBox: UIButton {

    //images
    let checkedImage = UIImage(named: "checkedbox")
    let unCheckedImage = UIImage(named: "uncheckedbox")


    //bool propety
    var isChecked:Bool = false{
        didSet {
            if isChecked == true{
                self.setImage(checkedImage, forState: .Normal)
            }
            else {
                self.setImage(unCheckedImage, forState: .Normal)
            }
        }
    }


    override func awakeFromNib() {
        self.addTarget(self, action: "buttonClicked:", forControlEvents: UIControlEvents.TouchUpInside)
    }



    func buttonClicked(sender:UIButton) {
        if(sender == self){
            if isChecked == false {
                isChecked = true
            } else {
                isChecked = false
            }
        }
    }


}

func doneHit(cell:TaskCell) {
        if let ip = tableView.indexPathForCell(cell) {
            var task = tasks[ip.row]
            task.done = cell.checkBox.isChecked
            if task.done == true {
                task.completedBy = "Completed by: \(self.user)"
                cell.label.textColor = UIColor.grayColor()
            }
            else {
                task.completedBy = ""
                cell.label.textColor = UIColor.blackColor()
            }
            let taskNameRef = self.ref.childByAppendingPath("tasks/\(task.title)")
            let completedByData = ["completedBy": "\(self.user)"]
            let doneData = ["done": task.done]
            taskNameRef.updateChildValues(completedByData)
            taskNameRef.updateChildValues(doneData)

        }
    }
 override func tableView(tableView: UITableView, cellForRowAtIndexPath indexPath: NSIndexPath) -> UITableViewCell {
        let cell = tableView.dequeueReusableCellWithIdentifier("TaskCell", forIndexPath: indexPath) as! TaskCell

        // Configure the cell...
        cell.selectionStyle = .None
        let idx = tasks[indexPath.row]
        if let label = cell.viewWithTag(1) as? UILabel {
            label.text = idx.title
            if idx.done == true {
            label.textColor = UIColor.grayColor()
            } else {
            label.textColor = UIColor.blackColor()
            }
            if let checkBox = cell.viewWithTag(2) as? CheckBox {
                checkBox.isChecked = idx.done
            }
            if let userCompleted = cell.viewWithTag(3) as? UILabel {
                if idx.done == true {
                    userCompleted.text = "Completed By: \(idx.completedBy)"
                }
                else {
                    userCompleted.text = ""
                }
            }
        }
        print("Task.done is: \(idx.done)")
        print("isChecked is:\(cell.checkBox.isChecked)")
        cell.delegate = self

        return cell
    }

1 个答案:

答案 0 :(得分:0)

3天后自己搞清楚了。我取消了Checkbox类并将复选框转换为UIImageView并添加了手势识别器。其余的只是将Checkbox逻辑移动到doneHit方法下的TaskTVC类中。