Swift не может вызвать функцию после нажатия кнопки - PullRequest
0 голосов
/ 14 мая 2018

Я сделал вид контейнера с изображением и кнопкой внутри по какой-то причине при запуске приложения в симуляторе. Я не могу нажать кнопку и вызвать функцию, которая выводит меня на следующий экран, я столкнулся с такой проблемой раньше, и это было так же просто, как изменить кнопку на ленивую переменную, хотя в этом случае это не сработало?

lazy var nameLabelButton = UIButton()




func setupNavBarWithUser() {

    guard let displayName = user?.DisplayName else { return }

    let titleView = UIView()
    titleView.frame = CGRect(x: 0, y: 0, width: 100, height: 40)
       titleView.backgroundColor = UIColor.red

    let containerView = UIView()
    containerView.translatesAutoresizingMaskIntoConstraints = false
    titleView.addSubview(containerView)

    let profileImageView = UIImageView()
    profileImageView.translatesAutoresizingMaskIntoConstraints = false
    profileImageView.contentMode = .scaleAspectFill
    profileImageView.layer.cornerRadius = 20
    profileImageView.clipsToBounds = true
    if let profileImageUrl = user?.profileImageURL {
        profileImageView.loadImageUsingCacheWithUrlString(urlString:profileImageUrl)
    }

    containerView.addSubview(profileImageView)

    //ios 9 constraint anchors
    //need x,y,width,height anchors
    profileImageView.leftAnchor.constraint(equalTo: containerView.leftAnchor).isActive = true
    profileImageView.centerYAnchor.constraint(equalTo: containerView.centerYAnchor).isActive = true
    profileImageView.widthAnchor.constraint(equalToConstant: 40).isActive = true
    profileImageView.heightAnchor.constraint(equalToConstant: 40).isActive = true


    containerView.addSubview(nameLabelButton)
    nameLabelButton.setTitle("\(displayName)", for: .normal)
    nameLabelButton.setTitleColor(.black, for: .normal)
    nameLabelButton.translatesAutoresizingMaskIntoConstraints = false
    //need x,y,width,height anchors
    nameLabelButton.leftAnchor.constraint(equalTo: profileImageView.rightAnchor, constant: 8).isActive = true
    nameLabelButton.centerYAnchor.constraint(equalTo: profileImageView.centerYAnchor).isActive = true
    nameLabelButton.rightAnchor.constraint(equalTo: containerView.rightAnchor).isActive = true
    nameLabelButton.heightAnchor.constraint(equalTo: profileImageView.heightAnchor).isActive = true

    containerView.centerXAnchor.constraint(equalTo: titleView.centerXAnchor).isActive = true
    containerView.centerYAnchor.constraint(equalTo: titleView.centerYAnchor).isActive = true

    nameLabelButton.addTarget(self, action: #selector(self.openUsersProfileController), for: .touchUpInside)



    self.navigationItem.titleView = titleView

}


func openUsersProfileController(){
    print("asdasdadsad")

    let openUsersProfileController = UserProfileController(collectionViewLayout: UICollectionViewFlowLayout())
    openUsersProfileController.user = self.user
    navigationController?.pushViewController(openUsersProfileController, animated: true)

}

1 Ответ

0 голосов
/ 14 мая 2018

хорошо, код выглядит хорошо, вам просто нужно добавить @objc

@objc func openUsersProfileController(){
        print("asdasdadsad")

        let openUsersProfileController = UserProfileController(collectionViewLayout: UICollectionViewFlowLayout())
        openUsersProfileController.user = self.user
        navigationController?.pushViewController(openUsersProfileController, animated: true)

    }

Причина

Начиная с Swift 4, нам нужно вручную добавить @objc перед функцией.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...