iOS开发中界面跳转有两种方式,上下跳转和左右跳转。

上下跳转_TO:

  1. let secondViewController = SecondViewController()
  2. self.presentViewController(secondViewController, animated: true, completion: nil)

上下跳转_BACK:

  1. dismissViewControllerAnimated(true, completion: nil)

-----------------------------------------------

-----------------------------------------------

左右跳转_TO:

(将新的视图控制器PUSH到navigationController中,相当于入栈操作)

  1. let secondViewController = SecondViewController()
  2. self.navigationController!.pushViewController(secondViewController, animated: true)

左右跳转_BACK:

(将当前视图控制器从导航视图控制器堆栈中移除,从而返回到了上一级界面)

( - ) BACK_到上一级:

  1. let firstViewController = FirstViewController()
  2. self.navigationController?.popViewControllerAnimated(true)

( - ) BACK_指定界面:

  1. // 获得视图控制器中的某一视图控制器
  2. let viewController = self.navigationController?.viewControllers[0]
  3. self.navigationController?.popToViewController(viewController as! UIViewController, animated: true)

( - ) BACK_根视图:

  1. self.navigationController?.popToRootViewControllerAnimated(true)

根视图的设置需要在AppDelegate中设置

  1. var window: UIWindow?
  2. func application(application: UIApplication, didFinishLaunchingWithOptions launchOptions: [NSObject: AnyObject]?) -> Bool
  3. {
  4. var firstViewController = FirstViewController()
  5. var rootNavigationViewController = UINavigationController(rootViewController: firstViewController)
  6. self.window!.rootViewController = rootNavigationViewController
  7. return true
  8. }

OC针对手写页面及storyboard制作页面,使用代码进行页面跳转的两种方法。

    1. 手写页面:

      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 界面跳转的更多相关文章

  1. Swift - 界面的跳转模式

    iOS开发中界面跳转有两种方式,上下跳转和左右跳转. 上下跳转_TO: let secondViewController = SecondViewController() self.presentVi ...

  2. IOS学习[Swift中跳转与传值]

    Swift中页面跳转与传值: 1.简单方式 首先,Swift的跳转可分为利用xib文件跳转与storyboard跳转两种方法,我这里选择使用storyboard的界面跳转方法. 1.通过在storyb ...

  3. Android 手机卫士--设置界面&功能列表界面跳转逻辑处理

    在<Android 手机卫士--md5加密过程>中已经实现了加密类,这里接着实现手机防盗功能 本文地址:http://www.cnblogs.com/wuyudong/p/5941959. ...

  4. iOS界面跳转的一些优化方案

    原文地址: http://blog.startry.com/2016/02/14/Think-Of-UIViewController-Switch/ iOS界面跳转的一些优化方案 App应用程序开发, ...

  5. Android activity界面跳转动画

    实现activity界面跳转动画 1.在startActivity方法之后加入: overridePendingTransition(R.anim.pull_in_right, R.anim.pull ...

  6. 如何优雅的实现界面跳转 之 统跳协议 - DarwinNativeRouter

    PS 感谢大家的关注,由于我本想开源4个库,除了router, 另外三个分别是native dispatcher, web dispatcher 和 react dispatcher , 所以rout ...

  7. ios中的界面跳转方式

    ios中,两种界面跳转方式 1.NavgationController本身可以作为普通ViewController的容器,它有装Controller的栈,所以可以push和pop它们,实现你所说的跳转 ...

  8. PyQt5实现界面跳转

    网上关于PyQt5的教程很少,特别是界面跳转这一块儿,自己研究了半天,下来和大家分享一下 一.首先是主界面 1 # -*- coding: utf-8 -*- # Form implementatio ...

  9. Android原生和H5交互;Android和H5混合开发;WebView点击H5界面跳转到Android原生界面。

    当时业务的需求是这样的,H5有一个活动商品列表的界面,IOS和Android共用这一个界面,点击商品可以跳转到Android原生的商品详情界面并传递商品ID:  大概就是点击H5界面跳转到Androi ...

随机推荐

  1. OC 面向对象的特性

    面向对象的编程语言有封装.继承 .抽象.多态4个主要的特征. 面向对象编程有三大特性:封装.继承.多态.   1. 封装: 封装是保证软件部件具有优良的模块性的基础,封装的目标就是要实现软件部件的“高 ...

  2. 1417. 重新格式化字符串--来源:力扣(LeetCode)

    题目描述: 给你一个混合了数字和字母的字符串 s,其中的字母均为小写英文字母. 请你将该字符串重新格式化,使得任意两个相邻字符的类型都不同.也就是说,字母后面应该跟着数字,而数字后面应该跟着字母. 请 ...

  3. xv6 操作系统的环境搭建

    xv6 是 MIT 设计的一个教学型操纵系统.xv6 可在 Intel X86 框架上运行,为了方便,建议将 xv6 运行在 QEMU 虚拟机器上,本人的实验环境是 ubuntu 18.04 . 1. ...

  4. 快速上手Alibaba Arthas

    点击返回上层目录 原创声明:作者:Arnold.zhao 博客园地址:https://www.cnblogs.com/zh94 Arthas 本文主要聚焦于快速上手并使用Arthas,所以对于基本的概 ...

  5. vs code插件自动压缩 min.css

    我们在进行相应的项目书写的时候,有些需要把scss 和 css 进行 压缩成 min.css 便于更好的使用 在这里强调一下 scss 后来才慢慢接触到这个语言的 感觉的确实懂得明白了之后  好用而且 ...

  6. php获取url?后面的拼接参数

    $outurl = urldecode($_SERVER['QUERY_STRING']);

  7. html文本超出加省略号

    如果实现单行文本的溢出显示省略号同学们应该都知道用text-overflow:ellipsis属性来,当然还需要加宽度width属来兼容部分浏览. 实现方法: overflow: hidden; te ...

  8. [前端开发]form-data和x-www-form-urlencoded的区别

    在后台开发时,之前做了文件的上传,用的是form-data,但并不知其区别.今天遇到了req.body为空的情况,切换成了x-www-form-urlencoded解决 form-data 就是htt ...

  9. Chisel3 - util - LFSR16

    https://mp.weixin.qq.com/s/DSdb4tmRwDTOki7mbyuu9A     实现16位线性反馈移位寄存器.可用于生成简单的伪随机数.     ​​     ​​   参 ...

  10. (一)用less+gulp+requireJs 搭建项目(了解less)

    项目完结 做个总结: 公司网站重构,整站都需要重写,终于有机会接触下 less,gulp和requireJs,因为以前的工作就是写几个活动页,并没有机会用这些工具,废话不多说,先看下完成后的项目目录: ...