从 UITabbarController 选择选项卡时如何更新 VC 中的值?

How to update the value in a VC when a tab is selected from a UITabbarController?

我有一个标签栏控制器。当用户单击其中一个选项卡栏按钮时,我需要更新目标视图控制器中的 UIPageViewController 中的值。

我正在尝试使用委托来通知 UIPageViewController 单击了哪个选项卡栏按钮:

protocol PlanTypeDelegate {
    func setIntro(thisFlow planType: UITabBarItem)
}

class NewTabBarController: UITabBarController {

var planTypeDelegate : PlanTypeDelegate?

override func viewDidLoad() {
        super.viewDidLoad()

        // create and handle tab bar button actions
}


override func tabBar(_ tabBar: UITabBar, didSelect item: UITabBarItem) {
        planTypeDelegate?.setIntro(thisFlow: item)
    }

在我的 UIPageController 中,我有以下内容:

class IntroPageController: UIPageViewController {

override func viewDidLoad() {
        super.viewDidLoad()

guard let tabbar = self.parent as? NewTabBarController() else { return }
    tabbar.delegate = self

}

}

extension IntroPageController : PlanTypeDelegate {
    func setIntro(thisFlow planType: UITabBarItem) {
        print("this item:\(planType)")
    }
}

相反,我收到此错误消息:

我不熟悉在 VC 之间传递数据,所以我不知道如何处理这种情况。

编辑 更新后同样的错误

你可以像这样实现它..没有委托......在IntroPageController中写setIntro方法我希望它能解决你的问题

class NewTabBarController: UITabBarController {
override func viewDidLoad() {
        super.viewDidLoad()
        self.delegate = self

    }
}
 func tabBarController(_ tabBarController: UITabBarController,
                          shouldSelect viewController: UIViewController) -> Bool{

        if let controller = viewController as? IntroPageController {

            controller.setIntro(thisFlow: tabBarController.tabBarItem)
        }
        return true
    }

您也可以通过写入协议来实现...所有确认 PlanTypeDelegate 的控制器都可以针对此方法执行操作

 func tabBarController(_ tabBarController: UITabBarController,
                          shouldSelect viewController: UIViewController) -> Bool{

        if let navController = viewController as? UINavigationController {
            if let myViewController  = navController.topViewController , let homeController = myViewController as? PlanTypeDelegate {
                homeController.setIntro(thisFlow: tabBarController.tabBarItem)
            }
        } else if let controller = viewController as? PlanTypeDelegate {

            controller.setIntro(thisFlow: tabBarController.tabBarItem)
        }
        return true
    }