Swift - 界面的跳转模式
iOS开发中界面跳转有两种方式,上下跳转和左右跳转。
上下跳转_TO:
- let secondViewController = SecondViewController()
- self.presentViewController(secondViewController, animated: true, completion: nil)
上下跳转_BACK:
- dismissViewControllerAnimated(true, completion: nil)
-----------------------------------------------
-----------------------------------------------
左右跳转_TO:
(将新的视图控制器PUSH到navigationController中,相当于入栈操作)
- let secondViewController = SecondViewController()
- self.navigationController!.pushViewController(secondViewController, animated: true)
左右跳转_BACK:
(将当前视图控制器从导航视图控制器堆栈中移除,从而返回到了上一级界面)
( - ) BACK_到上一级:
- let firstViewController = FirstViewController()
- self.navigationController?.popViewControllerAnimated(true)
( - ) BACK_指定界面:
- // 获得视图控制器中的某一视图控制器
- let viewController = self.navigationController?.viewControllers[0]
- self.navigationController?.popToViewController(viewController as! UIViewController, animated: true)
( - ) BACK_根视图:
- self.navigationController?.popToRootViewControllerAnimated(true)
根视图的设置需要在AppDelegate中设置
- var window: UIWindow?
- func application(application: UIApplication, didFinishLaunchingWithOptions launchOptions: [NSObject: AnyObject]?) -> Bool
- {
- var firstViewController = FirstViewController()
- var rootNavigationViewController = UINavigationController(rootViewController: firstViewController)
- self.window!.rootViewController = rootNavigationViewController
- return true
- }
OC针对手写页面及storyboard制作页面,使用代码进行页面跳转的两种方法。
▪ 手写页面:
var vc = ViewController()
self.presentViewController(vc, animated: true, completion: nil)▪ storyboard制作页面
var sb = UIStoryboard(name: "Main", bundle:nil)
var vc = sb.instantiateViewControllerWithIdentifier("VC") as ViewController
//VC为该界面storyboardID,Main.storyboard中选中该界面View,Identifier inspector中修改
self.presentViewController(vc, animated: true, completion: nil)self.performSegueWithIdentifier("VC", sender: nil)多个场景之间切换的样式(Style)总共有5个:
Modal(模态)
-- 过渡到另一个场景,以完成一项任务。任务完成后,将关闭该场景,并返回到原来的场景。
Push(压入)
-- 创建一个场景链,用户可在其中前后移动。用于导航视图控制器。
Replace(替换,仅适用于iPad)
-- 替换当前场景,用于一些iPad特有的视图控制器。
Popover(弹出框,仅适用于iPad) --
一个带箭头的弹出框。
Custome(自定义)
-- 通过编译在场景之间进行自定义过渡。
过渡类型(Transition)是从一个场景切换到另一个场景时播放的动画。有4个选项:
Cover Vertical
-- 新场景从下向上移动,逐渐覆盖旧场景。
Flip Horizontal
-- 视图水平翻转,以显示背面的新场景。
Cross Dissolve
-- 旧场景淡出,新场景淡入。
Partial Curl
-- 旧场景像书页一样翻开,显示下面的新场景。
在iPad应用程序中,还会多出一个Presentation属性,它决定了模态视图在屏幕上的显示方式。有4种显示样式:
Form Sheet(表单)
-- 将场景调整到比屏幕小(不管朝向),并在当前场景后面显示原始场景,这几乎相当于在一个iPad窗口中显示。
Page Sheet(页面)
-- 调整场景大小,使其以纵向格式显示。Full
Screen(全屏)
-- 调整场景大小,使其覆盖整个屏幕。
Current Context(当前上下文)
-- 以原始场景的显示方式展示场景。
要使用在故事板中定义的切换到另一个场景,但又不想自动触发该切换,可使用UIViewController的实例方法performSegueWithIdentifier:sender。调用该方法后,切换就将启动并发生过渡。应将参数sender设置为启动切换的对象。这样在切换期间,就可确定是哪个对象启动了切换。
- (IBAction)toConfigHandler:(id)sender {
//执行名为"toConfig"的切换
[self performSegueWithIdentifier:@"toConfig" sender:self];}调用UIViewController的方法dismissViewControllerAnimated:completion,可以关闭当前模态视图,返回到原始场景。completion是一个可选参数,用于指定过渡完毕后将执行的代码块。
- (IBAction)returnToMainHandler:(id)sender {
//关闭模态场景
[self dismissViewControllerAnimated:YES completion:nil];}以纯代码的方式创建模态场景切换:
//获取"MyMain.storyboard"故事板的引用UIStoryboard *mainStoryboard =[UIStoryboard storyboardWithName:@"MyMain" bundle:nil]; //实例化Identifier为"myConfig"的视图控制器
ConfigViewController *configVC = [mainStoryboard instantiateViewControllerWithIdentifier:@"myConfig"]; //为视图控制器设置过渡类型
configVC.modalTransitionStyle = UIModalTransitionStyleCoverVertical; //为视图控制器设置显示样式
configVC.modalPresentationStyle = UIModalPresentationFullScreen; //显示视图
[self presentViewController:configVC animated:YES completion:nil];视图的modalTransitionStyle(过渡类型)属性有以下枚举值:
UIModalTransitionStyleCoverVertical
-- 默认值,从下向上覆盖
UIModalTransitionStyleFlipHorizontal
-- 水平翻转
UIModalTransitionStyleCrossDissolve
-- 淡入淡出
UIModalTransitionStylePartialCurl
-- 像书页一样翻开以显示下面的视图
视图的modalPresentationStyle(显示样式)属性有以下枚举值:
UIModalPresentationFullScreen
-- 默认值,如何旋转都是全屏,iPhone下仅有这一个样式有效
UIModalPresentationFormSheet
-- 宽度和高度均会小于屏幕尺寸,居中显示,四周是变暗区域。仅适用于
iPadUIModalPresentationPageSheet
-- 在竖屏下和UIModalPresentationFullScreen表现一样,横屏下高度和当前屏幕高度相同,宽度和竖屏模式下屏幕宽度相同,剩余未覆盖区域将会变暗并阻止用户点击
UIModalPresentationCurrentContext
-- 与父视图的显示样式相同
Swift - 界面的跳转模式的更多相关文章
- ios 界面间跳转方法总结
接触ios也有一段时间了,偶然间,我们公司的技术总监兼我的导师,问我,你可知道,界面间的跳转有几种方式?我说出了两种,但是也有点含糊其辞,于是我就想一定要找个时间总结一下.有句话说的好,“前人种树,后 ...
- App设计:消息推送和界面路由跳转
概要 app消息推送.显示通知栏,点击跳转页面是很一般的功能了,下面以个推为例演示push集成,消息处理模块及app内部路由模块的简单设计. 推送 推送sdk集成 集成sdk步骤根据文档一步步做就行了 ...
- HTML5做的浏览器欢迎界面自动跳转
HTML5做的浏览器欢迎界面自动跳转 思路很简单,随手装逼呗.根据时间来控制背景图和文字,背景图加了毛玻璃效果,效果直接看图,用javascript来实现. 完整代码 <!DOCTYPE htm ...
- 上传头像,界面无跳转,php+js
上传头像,界面无跳转的方式很多,我用的是加个iframe那种.下面直接上代码. html: //route 为后端接口//upload/avatar 为上传的头像的保存地址//imgurl=/uplo ...
- abp + angular 前端使用 hash ,登录界面不跳转问题
abp 项目默认的路由没有使用hash,这会导致手动刷新浏览器时,页面404错误: 解决方法网上很多,就是在路由里添加一个{useHash: true},就行了. #用Hash带来的新问题# abp框 ...
- Swift 界面跳转
iOS开发中界面跳转有两种方式,上下跳转和左右跳转. 上下跳转_TO: let secondViewController = SecondViewController() self.presentVi ...
- swift 给导航添加item,实现界面的跳转
//给导航添加item var rightItem = UIBarButtonItem(title: "First", style: UIBarButtonItem ...
- winform程序中界面的跳转问题
首先是我们进行窗口间的跳转,尤其注意的是winform程序里面的空间都是中线程安全的.但是注意的是如果你在一个线程中操纵另外的控件,这时候会提示你一个错误,这个错误的解决方法准备单独的在另一篇文章中来 ...
- IOS第13天(1,私人通讯录,登陆功能,界面的跳转传值,自定义cell,编辑界面)
******HMLoginViewController 登陆的界面 #import "HMLoginViewController.h" #import "MBProgre ...
随机推荐
- .pop ----remove 删除
s = {1,2,3,4,5,6,'sn','7'} s.pop()#删除随机值 print(s)#{2, 3, 4, 5, 6, '7', 'sn'} s.remove('sn')#删除值 prin ...
- css实现了hover显示title的效果
<div data-title="hello, world">hello...</div> <style> div { position: re ...
- Asp.Net MVC<三> : ASP.NET MVC 基本原理及项目创建
MVC之前的那点事儿系列 解读ASP.NET 5 & MVC6系列 MVC模拟(摘自ASP.NET MVC5框架揭秘) Asp.net中,通过HttpModule的形式定义拦截器,也就是路由表 ...
- Jsoup 使用教程:输入
使用背景: 使用网络爬虫(或者手动复制),从别的网站上下载下来的内容,都是一堆的html,很多标签.样式 等等都可能是你所不需要的,或者 想要变成你想要的样式.那么该怎么办呢? 我们知道,每一个网页都 ...
- 【SQL】Oracle分页查询的三种方法
[SQL]Oracle分页查询的三种方法 采用伪列 rownum 查询前10条记录 ? 1 2 3 4 5 6 7 8 9 10 11 [sql] select * from t_user t whe ...
- Map工具系列-01-Map代码生成工具说明
所有cs端工具集成了一个工具面板 -打开(IE) Map工具系列-01-Map代码生成工具说明 Map工具系列-02-数据迁移工具使用说明 Map工具系列-03-代码生成BySQl工具使用说明 Map ...
- 关于line-height
line-height不允许负值,给定值之后会根据font-size计算行高,line-height指定的行高是行高最小值,设置height可以增大行高 line-height的计算:以px为例,li ...
- [C#] 图文解说调用WebServer实例
本文旨在实现如何在.NET环境下调用WebServer,以天气接口为例进行说明. WebServer地址:http://www.webxml.com.cn/WebServices/WeatherWeb ...
- js 中关于this用变量存起来的原因
近来,不忙,总是在网上看大牛的博客,发现关于this指向的情况,有的说是4种,也对,有的就是总结一句话,也对,但是我发现一种特殊情况,例子如下 var show={ btn:$('.div1'), i ...
- oracle---plsql---示例laobai
select * from scott.emp; --1 列出emp表中各部门的部门号,最高工资,最低工资 select deptno,max(sal),min(sal) from scott.emp ...