【我们都爱Paul Hegarty】斯坦福IOS8公开课个人笔记21 深入多MVC模式、Segue过渡

简介: 上一话中我们介绍了多MVC模式并且以导航控制器为例讲解了这三个控制器管理多个MVC的工作原理。

上一话中我们介绍了多MVC模式并且以导航控制器为例讲解了这三个控制器管理多个MVC的工作原理。那么我们如何得到控制器所管理的MVC呢。


控制器中有一个属性叫做viewControllers,它是一个UIViewController类型的数组。它里面存储的是一个系统中的所有ViewController,在分栏控制器中只会有两个控制器(Master和Detail),在导航栏控制器中会有Tab数目个控制器,而在导航控制器中会有堆栈中卡片数目个元素。通常我们不会对它设值,但是设值是可以的,这有点奇怪。这个设值操作通常是通过在storyboard中操作进行的。

那么如何获得一个导航控制器呢,如何获得它的指针,答案是每一个视图控制器都知道自己是不是身处一个导航控制器或者是分栏和选项卡控制器之中。因为视图控制器有三个属性tabBarController、splitViewController和navigationController,这些属性会返回给你它处在哪个父控制器中,如果它不在,会返回nil,这些属性可以超过一个不同时为nil,代表它处在多个父控制器中。例如某个MVC在分栏控制器中是master的角色,它想要获取detail角色的MVC,那么它访问splitViewController这个属性,然后访问viewController[1],我们知道viewController[1]这个属性代表分栏控制器中的detail。一旦获取到那么这个master就可以给它的detail发消息了。

但是我们通常不需要这么做,我们可以在storyboard中完成大部分操作,那么我们在storyboard中如何连接起这些MVC呢


以分栏控制器为例,你拖到storyboard中的时候它会带出一串已经关联好的MVC,但是通常你会删掉这些以连接你自己的MVC,你需要保留的是分栏控制器本身。

然后我们用之前常用的右键拖拽法就能实现连接:


松手的时候会提示你想要建立什么样的连接:



我们选择Master View Controller。这样就建立了一个连接,我用同样的方法拖拽到Detail上。这次选择Detail View Controller。


导航控制器有一些不同,稍后我们会看到。


但是这里有一个问题就是分栏显示视图不能在iphone上显示,确切地说事ip6 plus以外的iphone上,因为ip6 plus横屏的显示模式是和ipad一样的。那么如何在iphone上显示Master和Detail呢,答案是利用导航控制器,我们在我们的Master加上一个导航控制器,方法是选中控制器然后点击editor选中Embed in然后选择 Navigation Controller。


现在这个Master已经嵌到一个导航控制器中了。这种方法是通用的,而且这时导航控制器成了分栏控制器中的Msster,这点要注意。我们同样可以在Detail中嵌入一个导航控制器。


这样做的好处是我们可能会用到导航栏的标题栏,增加一些按钮之类的功能,但是我们从来不会用Detail做导航,因为它只会被导航,它自身不需要一个导航控制器。


那么接下来该如何显示它们,我们在Master中做了一些改变需要在Detail中显示,那么该如何来做?答案是Segues(过渡)


过渡是一个控制器转到另一个控制器的方法。IOS中定义了四种不同的过渡,当然你还可以自己定义过渡。

1.Show Segue:展示你正在交互的那个MVC,如果你是个导航控制器,那么它就会将这个MVC置于卡片的堆栈之上并显示它,如果你不是个导航控制器,那么它会议Modally的方式展示这个MVC

2.Show Detail Segue和show Segue非常像。唯一的区别是这个过渡在分栏控制器中在Detail中显示这个MVC。如果你在一个导航控制器中使用这个过渡,那么它和Show Segue的效果是一样的。

3.Modal Segue:它会以占满屏幕的方式显示这个MVC,我不太推荐Modal,因为如果没有返回的操作那么APP就卡在当前页面了。

4.Popover Segue:弹出Segue的目标view Controller,并让这个view Controller显示在其他东西之上,但是并不布满整个屏幕。但实际上它是布满整个屏幕的,因为用户只能与这个弹出的窗口进行交互。如果用户点击了窗口外的区域,就会取消这个popover窗口。它比Modal好的地方是,尽管它并不占满整个屏幕,但是用户可以让窗口背后的用户界面变灰暗,你点击这些灰暗的部分会让窗口弹走,所以popover很容易被取消。

最后需要讲到的是无论你使用哪种方式,转到的MVC都是新创建的,你不会过渡到一个已经存在的MVC中。


那么我们该如何创建这些过渡呢,你可以通过代码来创建,但是大部分情况我们都是通过storyboard拖动来创建的。下面是一个示例:


我在Master上加了一个小按钮,拖拽按钮到Detail上松手然后选择过渡的方式:


我们选择Show Detail。因为这是个分栏控制器,我想要完全替代Detail,如果这是一个导航控制器的话,我也许依旧选择show detail,因为我希望它被推入栈中,但是如果是在Master中就不会选择show detail,我希望它存在在master的栈中,这时会用show。这时会出现一条线。


点击这条线你会在右边看到这个过渡的属性,还有一个很重要的区域叫做Identifier,这是你的过渡的唯一标志。


这里我们把刚刚创建的过渡命名为Show Graph。一般来说你的命名应该能让别人看出这个过渡的作用。

之前说过storyboard中的所有东西都是通过名字和你的代码连接在一起的。不管是UIview的名字、UIViewController的名字,还是action和outlet的名字,还有这里的segue的名字,也就是这个Identifier,它们都是名字,我们需要让storyboard中的名字和代码中的名字相同,这是一种松散的耦合,能让两个东西连接在一起。那么我们在代码中如何用到这个名字呢?


第一种方法很简单,就是在代码中触发segue,方法是使用UIViewController的performSegueWithIdentifier方法,这种方法很少用。

第二种方法是使用Identifier为segue做准备,因为如果segue被触发,那么它们就会新建一个MVC,这个MVC需要一些准备才能做你想让它做的事情。比如在Calculator这个Demo中我们要绘制曲线图,但是MVC创建的时候是一张空的,它需要数据,所以我们需要做准备。那么该如何做准备呢?MVC包含一个segue的发起者,MVC实现了一个方法叫做prepareForSegue,在这里面它包含着刚刚创建的MVC。


第一个参数就是segue,这个segue里面有两个非常重要的属性,第一个是Identifier,让你知道为哪个segue做准备。第二个是这个segue新建的那个MVC,名字叫做destinationViewController,这个属性是一个AnyObject类型的,所以你需要解包它,注意在新的Swift1.2版本中这种AnyObject的解包已经全部使用as!了

第二个参数叫做sender,比如UIButton或者其他触发这个segue的东西,一般来说你不会用到这个参数。


请注意上面这张幻灯片上的红色字体,当你做准备的时候,页面上的outlet还没有被创建。我们之前讲过这些outlet是隐性解包的,如果你想要做一些关于outlet的属性的操作需要暂存到一个地方,不然会造成程序的崩溃,比如可以把一些操作放到outlet中属性的属性观察器中。

你也可以防止一个segue的发生。


如果有一些事情不允许触发,那么我们可以把这个触发segue禁掉(比如按钮不能按下)

目录
相关文章
|
7月前
|
设计模式 存储 前端开发
MVVM、MVC、MVP三种常见软件架构设计模式的区别
MVC、MVP 和 MVVM 是三种常见的软件架构设计模式,主要通过分离关注点的方式来组织代码结构,优化开发效率。
152 12
|
8月前
|
设计模式 前端开发 JavaScript
浅谈MVC、MVP、MVVM框架模式
浅谈MVC、MVP、MVVM框架模式
73 0
|
8月前
|
前端开发 数据安全/隐私保护
什么是mvvm,mvp、mvc和mvvm模式有什么区别?
什么是mvvm,mvp、mvc和mvvm模式有什么区别?
141 0
|
7月前
|
设计模式 存储 前端开发
MVC(Model-View-Controller)是一种软件设计模式,用于将应用程序的输入逻辑、业务逻辑和用户界面逻辑分离
【6月更文挑战第17天】**MVC模式**是软件设计模式,用于分离输入逻辑、业务逻辑和用户界面。模型处理数据和业务,视图展示数据,控制器协调两者响应用户请求。优点包括:关注点分离、提高开发效率、简化测试、支持多视图及便于大型项目管理。
65 3
|
3月前
|
存储 前端开发 测试技术
MVC、MVP、MVVM 模式
MVC、MVP 和 MVVM 是三种常见的软件架构模式,用于分离用户界面和业务逻辑。MVC(Model-View-Controller)通过模型、视图和控制器分离数据、界面和控制逻辑;MVP(Model-View-Presenter)将控制逻辑移到 Presenter 中,减少视图的负担;MVVM(Model-View-ViewModel)通过数据绑定机制进一步解耦视图和模型,提高代码的可维护性和测试性。
|
8月前
|
设计模式 存储 前端开发
MVC(模型-视图-控制器)是一种在Web应用程序开发中广泛使用的软件设计模式
【5月更文挑战第12天】MVC模式是Web应用开发中的常见设计模式,将逻辑、数据和界面分离,提升代码可维护性和重用性。模型处理数据逻辑,视图展示数据,控制器协调用户输入与模型视图交互。优点包括代码分离、易维护、可扩展和组件重用,促进高效灵活的开发。
79 2
|
4月前
|
设计模式 开发框架 前端开发
MVC 模式在 C# 中的应用
MVC(Model-View-Controller)模式是广泛应用于Web应用程序开发的设计模式,将应用分为模型(存储数据及逻辑)、视图(展示数据给用户)和控制器(处理用户输入并控制模型与视图交互)三部分,有助于管理复杂应用并提高代码可读性和维护性。在C#中,ASP.NET MVC框架常用于构建基于MVC模式的Web应用,通过定义模型、控制器和视图,实现结构清晰且易维护的应用程序。
72 2
|
3月前
|
前端开发 Java
【案例+源码】详解MVC框架模式及其应用
【案例+源码】详解MVC框架模式及其应用
223 0
|
4月前
|
前端开发 测试技术 开发者
MVC模式在现代Web开发中有哪些优势和局限性?
MVC模式在现代Web开发中有哪些优势和局限性?
|
4月前
|
设计模式 前端开发 PHP
PHP中实现简易的MVC模式
【8月更文挑战第31天】 本文将引导你了解如何在PHP中应用MVC(Model-View-Controller)架构模式,通过一个简单的例子展示其实现过程。我们将从基础的概念出发,逐步深入到代码实践,最终让你能够自己动手构建一个简易的MVC框架。文章不仅提供理论知识,还包含具体的代码示例,帮助你更好地理解并运用MVC模式。