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 界面跳转的更多相关文章
- Swift - 界面的跳转模式
iOS开发中界面跳转有两种方式,上下跳转和左右跳转. 上下跳转_TO: let secondViewController = SecondViewController() self.presentVi ...
- IOS学习[Swift中跳转与传值]
Swift中页面跳转与传值: 1.简单方式 首先,Swift的跳转可分为利用xib文件跳转与storyboard跳转两种方法,我这里选择使用storyboard的界面跳转方法. 1.通过在storyb ...
- Android 手机卫士--设置界面&功能列表界面跳转逻辑处理
在<Android 手机卫士--md5加密过程>中已经实现了加密类,这里接着实现手机防盗功能 本文地址:http://www.cnblogs.com/wuyudong/p/5941959. ...
- iOS界面跳转的一些优化方案
原文地址: http://blog.startry.com/2016/02/14/Think-Of-UIViewController-Switch/ iOS界面跳转的一些优化方案 App应用程序开发, ...
- Android activity界面跳转动画
实现activity界面跳转动画 1.在startActivity方法之后加入: overridePendingTransition(R.anim.pull_in_right, R.anim.pull ...
- 如何优雅的实现界面跳转 之 统跳协议 - DarwinNativeRouter
PS 感谢大家的关注,由于我本想开源4个库,除了router, 另外三个分别是native dispatcher, web dispatcher 和 react dispatcher , 所以rout ...
- ios中的界面跳转方式
ios中,两种界面跳转方式 1.NavgationController本身可以作为普通ViewController的容器,它有装Controller的栈,所以可以push和pop它们,实现你所说的跳转 ...
- PyQt5实现界面跳转
网上关于PyQt5的教程很少,特别是界面跳转这一块儿,自己研究了半天,下来和大家分享一下 一.首先是主界面 1 # -*- coding: utf-8 -*- # Form implementatio ...
- Android原生和H5交互;Android和H5混合开发;WebView点击H5界面跳转到Android原生界面。
当时业务的需求是这样的,H5有一个活动商品列表的界面,IOS和Android共用这一个界面,点击商品可以跳转到Android原生的商品详情界面并传递商品ID: 大概就是点击H5界面跳转到Androi ...
随机推荐
- h5+ 开发分享功能
h5+ 开发微信.QQ分享功能 此处只做微信网页分享示例代码 方式一.JS+HTML+h5Plus 1.html代码 <div class="button" onclick= ...
- dom4j——使用dom4j生成xml
使用org.dom4j.Element 创建xml /** * 生成Service.xml文件 * @param tran 交易对象 * @param filePath 文件夹路径 */ public ...
- Swiper的jquery动态渲染不能滑动
<!-- 下面俩行代码就是解决异步加载数据导致swiper不轮播的关键 --> observer: true,//修改swiper自己或子元素时,自动初始化swiper observePa ...
- Mysql数值类型,小数点后保留两个零
如有不足请帮忙留言区补充谢谢~ 一,数值类型保留小数点后两个0 在存入数据时,应客户需求数值类型,比如钱数,分数等等需要精确到小数点后几位. 800存入时显示为800.00 方法:在建表时直接定义此数 ...
- Kubernetes实战 - 从零开始搭建微服务 - 1.5 提高可用性-发布多节点的Node/Express网络应用程序
1.5 提高可用性-发布多节点的Node/Express网络应用程序 Kubernetes实战 - 从零开始搭建微服务 前言 在上一篇文章中,已经学习了如何简单地开发一个单层网络应用.[Kuberne ...
- DQN(Deep Q-learning)入门教程(三)之蒙特卡罗法算法与Q-learning算法
蒙特卡罗法 在介绍Q-learing算法之前,我们还是对蒙特卡罗法(MC)进行一些介绍.MC方法是一种无模型(model-free)的强化学习方法,目标是得到最优的行为价值函数\(q_*\).在前面一 ...
- 14.Java连接Redis_Jedis_主从模式
redis的主从模式之前提到过,这里我们使用redis来实现主从模式. 首先在VMware虚拟机中的Linux中打开两个终端,一个是用户jack,一个是newuser: 然后我们jack作为主机,re ...
- JavaScript实现树深度优先和广度优先遍历搜索
1.前置条件 我们提前构建一棵树,类型为 Tree ,其节点类型为 Note.这里我们不进行过多的实现,简单描述下 Note 的结构: class Node{ constructor(data){ t ...
- 2020本科校招-从小白到拿到30k offer的学习经历
本文是个人的2020年年中总结 还有十几天就要毕业,面临着身份从学生到互联网社畜的转变,未来的一切捉摸不定,但凡心中万千情绪,也只能「但行好事,莫问前程」. 介绍下博主背景:计算机本科大四,刚进大三时 ...
- Chisel3 - Tutorial - VendingMachine
https://mp.weixin.qq.com/s/tDpUe9yhwC-2c1VqisFzMw 演示如何使用状态机. 参考链接: https://github.com/ucb-bar/ch ...