How to access index path of button in a custom TableViewCell?

前端 未结 3 411
半阙折子戏
半阙折子戏 2020-12-21 08:04

I have created a custom TableViewCell and currently have a button placed in the cell. When the button is pressed, In the tableviewcell.swift file,

相关标签:
3条回答
  • 2020-12-21 08:36

    You could subclass UIButton in your cell with a property for its row.

    class MyButton: UIButton {
        var row: Int?
    }
    

    Then when you set up your table view, in the cellForRowAtIndexPath method, you set the row property:

    override func tableView(tableView: UITableView, cellForRowAtIndexPath indexPath: NSIndexPath) -> UITableViewCell {
            // ...
            cell.button.row = indexPath.row
            // ...
        }
    

    This way when the action fires, you can get the correct row:

    @IBAction func employeeAtLunch(sender: MyButton) {
        if let row = sender.row {
            // access the row
        }
    }
    
    0 讨论(0)
  • 2020-12-21 08:36

    In your situation, I will add a tag to your button to identify in which row it is. Whenever I configure cell in the call-back cellForRowAtIndexPath, I update this tag value.

    When a button clicked, the handler specifies always the button pressed. With the tag defined to that pressed button, you can know the button of which row is pressed.

    @IBAction func buttonPressed(sender: AnyObject) {
          //convert to UIButton
          if let btn = sender as? UIButton {
               let rowId = btn.tag
               //do your works
          }
    }
    

    If your tableview has more than 1 sections, you will have to setup the value of tags the right way.

    The second solution which is better: get the position of the button in your tableView, then get indexpath of that position in your tableview:

    let position = sender.convertPoint(CGPointZero, toView: self.tblMain)
    let indexPath = self.tblMain.indexPathForRowAtPoint(position)
    
    0 讨论(0)
  • 2020-12-21 08:57

    You are just assuming that the cell's immediate superview is the table view - wrongly. There is no particular reason why that should be so (and indeed it is not). Work with fewer assumptions! You need to keep walking up the superview chain until you do reach the table, like this:

    var v : UIView = self
    do { v = v.superview! } while !(v is UITableView)
    

    Now v is the table view, and you can proceed to work out what row this is.

    What I would actually do, however, is work my up, not from the cell to the table, but from the button to the cell. The technique is exactly the same:

    var v : UIView = sender as! UIView
    do { v = v.superview! } while !(v is UITableViewCell)
    

    Do that the button's action method, where sender is the button. If the target of the action method is the table view controller, it has access to the table, and the problem is solved.

    0 讨论(0)
提交回复
热议问题