目前我有一个连接到tableview控制器的标签栏控制器。当我按下标签栏项目时,我试图转到桌面视图的顶部。我知道如何到达tableview的顶部。我只是不知道如何在按下项目时执行操作。
答案 0 :(得分:27)
您应该使用方法UITabBarDelegate
didSelectItem
。将它用作任何标准代表:
class yourclass: UIViewController, UITabBarDelegate {
func tabBar(tabBar: UITabBar, didSelectItem item: UITabBarItem) {
//This method will be called when user changes tab.
}
}
不要忘记在视图控制器中将标签栏委托设置为self
。
答案 1 :(得分:15)
Here is an answer to this question
基本上你这样做:
实现didSelectItem方法,如下所示:
-(void)tabBar:(UITabBar *)tabBar didSelectItem:(UITabBarItem *)item {
if(item.tag == 1) {
//your code for tab item 1
}
else if(item.tag == 2) {
//your code for tab item 2
}
}
这样,您就可以访问每个标签项目分享事件。希望它有所帮助!
答案 2 :(得分:9)
SWIFT 3
class yourclass: UIViewController, UITabBarDelegate {
func tabBar(_ tabBar: UITabBar, didSelect item: UITabBarItem) {
print("Test")
}
}
不要忘记在viewDidLoad
中将tabBar委托设置为selfoverride func viewDidLoad(){
super.viewDidLoad()
<YOUR TAB BAR NAME>.delegate = self
}
答案 3 :(得分:6)
我在这里实施其他答案时遇到了麻烦。这是一个更全面的答案。它假设您使用UITabBarController
(如果您创建新的选项卡式应用程序,则为默认值)。每次点击视图控制器选项卡按钮时,此解决方案都会打印一条消息。
创建一个名为 MyTabBarController.swift 的新Swift文件。粘贴以下代码。
import UIKit
class MyTabBarController: UITabBarController, UITabBarControllerDelegate {
override func viewDidLoad() {
super.viewDidLoad()
// tell our UITabBarController subclass to handle its own delegate methods
self.delegate = self
}
// called whenever a tab button is tapped
func tabBarController(_ tabBarController: UITabBarController, didSelect viewController: UIViewController) {
if viewController is FirstViewController {
print("First tab")
} else if viewController is SecondViewController {
print("Second tab")
}
}
}
在故事板上选择标签栏控制器。然后在Identity检查器中,将类名设置为MyTabBarController
(即上面代码中类的名称)。
这就是全部。您可以立即运行您的应用,并在用户点击标签栏项时收到通知。
如果您需要在点击时运行方法,那么您可以在didSelect
方法中执行以下操作。
if let firstVC = viewController as? FirstViewController {
firstVC.doSomeAction()
}
您可以让FirstViewController
实现委托并处理其中的所有内容。这样您就不需要创建任何自定义UITabBarController
子类并在IB中设置它。然而,让孩子做父母的工作似乎是错误的地方。无论如何,这是:
class FirstViewController: UIViewController, UITabBarControllerDelegate {
override func viewDidLoad() {
super.viewDidLoad()
tabBarController?.delegate = self
}
func tabBarController(_ tabBarController: UITabBarController, didSelect viewController: UIViewController) {
// ...
}
}
无论点击哪个标签,都会调用上面的didSelect
方法。
答案 4 :(得分:4)
另一种解决方案是在viewDidAppear
中的任何一个View Controller中显示一些内容。
第一个标签视图控制器
import UIKit
class FirstViewController: UIViewController {
override func viewDidAppear(_ animated: Bool) {
super.viewDidAppear(animated)
print("First tab")
}
}
第二个标签视图控制器
import UIKit
class SecondViewController: UIViewController {
override func viewDidAppear(_ animated: Bool) {
super.viewDidAppear(animated)
print("Second tab")
}
}
答案 5 :(得分:0)
class TestViewController: UIViewController,UITabBarDelegate {
@IBOutlet weak var tabbar: UITabBar!
override func viewDidLoad() {
super.viewDidLoad()
tabbar.delegate = self
}
func tabBar(_ tabBar: UITabBar, didSelect item: UITabBarItem) {
print(tabBar.items![1]) // The number is tab index
}
}