ios页面间跳转方式总结

简介:

下面以OldViewController(oldC)的按钮btn点击后跳转到NewViewController(newC)为例说明:

1.Storyboard的segues方式

 鼠标点击按钮btn然后按住control键拖拽到newC页面,在弹出的segue页面中选择跳转模式即可

优点:操作方便,无代码生成,在storyboard中展示逻辑清晰

缺点:页面较多时不方便查看,团队合作时可维护性差,  多人合作时不建议使用这种方式

2.选项卡UITabBarController控制器

通过调用UITabBarController的addChildViewController方法添加子控制器

实例代码:

UITabBarController  *tabbarVC = [[ UITabBarController  alloc ] init ];   

    Old ViewController  *oldC = [[  Old ViewController  ] init ];

    oldC.  tabBarItem .  title =  @"控制器1 " ; 

    oldC. tabBarItem . image = [ UIImage imageNamed : @"old.png"  ];

    NewViewController  *newC = [[NewViewController ] init ];

    newC.  tabBarItem .  title =  @"控制器2 " ; 

    newC. tabBarItem  . image  = [ UIImage  imageNamed : @"new.png" ];

    // 添加子控制器(这些子控制器会自动添加到UITabBarController的  viewControllers 数组中) 

    [tabbarVC  addChildViewController :recent]; 

    [tabbarVC  addChildViewController :friends]; 

优点:代码量较少

缺点:tabbar的ios原生样式不太好看,(不常用,目前不建议使用),如果要使用,建议自定义tabbar

3.导航控制器UIN  avigationController

在oldC的btn的监听方法中调用:

[self.navigationController pushViewController:newC animated:YES]; //跳转到下一页面

在newC的方法中调用:

[self.navigationController popViewControllerAnimated:YES]; //返回上一页面  

当有多次跳转发生并希望返回根控制器时,调用:

[  self .navigationController popToRootViewControllerAnimated:  YES ];  //返回根控制器,即最开始的页面 

4.利用  Modal 形式展示控制器 

在oldC中调用:

[  self presentViewController:newC animated:  YES completion:nil]; 

在newC中调用:

[  self dismissViewControllerAnimated:  YES completion:  nil ]; 

5.直接更改 UIWindow  的 rootViewController 

按钮响应方法中加入,最好使用UINavigationController进行跳转.

UIWebView *myWebView=[[UIWebViewalloc] initWithFrame:CGRectMake(0, 20, 320, 300)];
   NSURL *url=[NSURLURLWithString:@"
"];
   NSURLRequest *request=[[NSURLRequestalloc] initWithURL:url];
   [myWebView loadRequest:request]; 
    [self.view addSubview:myWebView];

总结:

Storyboard方式适合个人开发小程序时使用,有团队合作或者项目较大时不建议使用

UITabBarController因为目前系统的原生样式不太美观,不建议使用

推荐使用UINavigationController和Modal,无明显缺点,而且目前大部分程序都使用这两种方式,只是看是否需要导航控制器而确定使用哪种方案










本文转自 卓行天下  51CTO博客,原文链接:http://blog.51cto.com/9951038/1828721,如需转载请自行联系原作者
目录
相关文章
|
4月前
|
Web App开发 移动开发 Android开发
解决IOS Safari浏览器H5页面上下滑动时卡顿、页面缺失的问题
解决IOS Safari浏览器H5页面上下滑动时卡顿、页面缺失的问题
|
4月前
|
iOS开发
ios中,输入框获得焦点时,页面输入框被遮盖,定位的元素位置错乱
ios中,输入框获得焦点时,页面输入框被遮盖,定位的元素位置错乱
35 1
|
8月前
|
移动开发 自然语言处理 JavaScript
移动端H5使用window.open跳转,IOS不生效解决
移动端H5使用window.open跳转,IOS不生效解决
566 2
|
9月前
|
前端开发 API Android开发
Android侧滑踩坑记(仿IOS侧滑finish页面基于Slidr库)
Android侧滑踩坑记(仿IOS侧滑finish页面基于Slidr库)
179 0
|
11月前
|
iOS开发
iOS app跳转到系统设置页面方法
iOS app跳转到系统设置页面方法
157 0
|
11月前
|
iOS开发
iOS dismiss到前两级页面
iOS dismiss到前两级页面
83 0
|
11月前
|
iOS开发
iOS WKWebView 打开页面空白URL为空问题解决办法
iOS WKWebView 打开页面空白URL为空问题解决办法
515 0
|
敏捷开发 安全 Unix
iOS开发 - 在实战中挖掘之线程间的通信方式
iOS开发 - 在实战中挖掘之线程间的通信方式
153 0
|
iOS开发
iOS开发 - 点击tabbar某一个item,直接push跳转进入需要的页面,而不是切换tab
iOS开发 - 点击tabbar某一个item,直接push跳转进入需要的页面,而不是切换tab
372 0
|
移动开发 JavaScript weex
weex-自定义module,实现weex在iOS的本地化,js之间互相跳转,交互,传值(iOS接入weex的最佳方式)
weex-自定义module,实现weex在iOS的本地化,js之间互相跳转,交互,传值(iOS接入weex的最佳方式)
219 0