it-roy-ru.com

Селектор в Swift3

Почему это не работает в Swift 3? Вылетает во время выполнения, говоря: 

'- [my_app_name.displayOtherAppsCtrl tap:]: нераспознанный селектор отправлен к экземпляру 0x17eceb70 '

    override func viewDidLoad() {
    super.viewDidLoad()

    // Uncomment the following line to preserve selection between presentations
    // self.clearsSelectionOnViewWillAppear = false

    // Register cell classes
    //self.collectionView!.register(ImageCell.self, forCellWithReuseIdentifier: reuseIdentifier)

    // Do any additional setup after loading the view.

  let lpgr = UITapGestureRecognizer(target: self, action: Selector("tap:"))
    lpgr.delegate = self
    collectionView?.addGestureRecognizer(lpgr)
}

func tap(gestureReconizer: UITapGestureRecognizer) {
if gestureReconizer.state != UIGestureRecognizerState.ended {
  return
}

let p = gestureReconizer.location(in: self.collectionView)
let indexPath = self.collectionView?.indexPathForItem(at: p)

if let index = indexPath {
  //var cell = self.collectionView?.cellForItem(at: index)
  // do stuff with your cell, for example print the indexPath
  print(index.row)
} else {
  print("Could not find index path")
}
}
47
Chris

Selector("tap:") теперь должен быть записан как #selector(tap(gestureReconizer:))

Кроме того, вы должны объявить tap как func tap(_ gestureRecognizer: UITapGestureRecognizer) согласно новым Swift API Guidelines в этом случае ваш селектор станет #selector(tap(_:)).

122
jjatie

В Swift 3 это работает так:

@IBOutlet var myView: UIView!
override func viewDidLoad() {
    super.viewDidLoad()

    let tap = UITapGestureRecognizer(target: self, action:#selector(handleTap))

    myView.addGestureRecognizer(tap)
}

func handleTap() {
    print("tapped")
}
19
Neen

Swift 3 поставляется с новым синтаксисом, поэтому вместо использования Selector («tap:»), #selector (tap (жестReconizer :)) 

2
Zeeshan

Свифт 3:

class MYPTempController: UIViewController {

    override func viewDidLoad() {
        super.viewDidLoad()

        let btn = UIButton(frame: CGRect(x: 0, y: 0, width: 100, height: 100))
        view.addSubview(btn)
        btn.addTarget(self, action: #selector(MYPTempController.btnClick), for: .touchUpInside)
    }
    @objc fileprivate func btnClick() {
        print("--click--")
    }
}

//带参数
btn.addTarget(self, action: #selector(MYPTempController.btnClick(_:)), for: .touchUpInside)
//监听方法
func btnClick(_ sender: UIButton) {
    print("--click--")
}
0
GeekMeng