- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我有一个允许用户登录和注册的 HomeController。如果用户点击登录,我会使用 segue 打开一个模态视图。
在模态视图中有一个按钮,上面写着注册。所需的操作是关闭登录模态视图,然后使用 performSegueWithIdentifier:
- (void)loginControllerDidRegister:(LoginController *)controller sender:(id)sender
{
NSLog(@"loginControllerDidRegister");
[self dismissViewControllerAnimated:YES completion:nil];
[self performSegueWithIdentifier:@"RegistrationSegue" sender:sender];
}
这正确地取消了模态视图,然后它调用了 performSegueWithIdentifier:
,其中我有日志代码显示它正在被调用,就好像我按下了注册按钮一样。
我认为登录模态视图消失的动画可能会干扰第二个模态视图的显示。关于如何解决这个问题有什么想法吗?
最佳答案
好吧,您需要启动“第二模式”vc。这就是“prepareForSegue:”方法的作用。您还需要覆盖“执行:”方法。这将比您想象的要复杂一些。如果有帮助,这里是 segue 如何工作的分割...
- (void)prepareForSegue:(UIStoryboardSegue *)segue sender:(id)sender;
被调用并传入“segue”。幕后花絮
- (id)initWithIdentifier:(NSString *)identifier source:(UIViewController *)source destination:(UIViewController *)source;
被调用,这就是创建“segue”的地方。
“segue”对象具有以下属性
(NSString *)identifier
(UIViewController *)sourceViewController
(UIViewController *)destinationViewController
没有这些,就无法执行 segue。这些类似于手动分配您的 View Controller
SomeViewController *secondView = [SomeViewController alloc] initwithNibName:@"SomeViewController" bundle:nil];
然后
[[segue destinationViewController] setModalTransitionStyle:UIModalTransitionStyle(...)];
这是...
secondView.modalTransitionStyle = UIModalTransitionStyle(...);
(...) 将是 Storyboard中选择的“segue”过渡。
最后
[[segue sourceViewController] presentModalViewController:destinationViewController animated:YES];
这只是
[self presentModelViewController:secondView animated:YES];
是让这一切发生的原因。您基本上必须对引擎盖下的那些进行调整才能获得您想要的工作,但它是可行的。
关于ios - 关闭模态视图然后执行 segue 以打开第二个模态视图,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10451659/
阅读目录 1、视图介绍 2、创建视图 3、查询视图 4、修改视图 5、删除视图 6、检查选项
基于函数的视图你已经get了,基于类的视图get了吗?CBV本质不知道?点进来看源码分析~ Django 视图之FBV 与 CBV FBV(function base views) 基于函数的视图,就
SQLite 视图(View) 视图(View)只不过是通过相关的名称存储在数据库中的一个 SQLite 语句。视图(View)实际上是一个以预定义的 SQLite 查询形式存在的表的组合。 视图
视图 什么是视图?视图的作用是什么? 视图(view)是一种虚拟存在的表,是一个逻辑表,它本身是不包含数据的。作为一个select语句保存在数据字典中的。 通过视图,可以展现基表(用来创建视图
代码如下: CREATE OR REPLACE VIEW BLOG_V_ADMIN (ID,NICKNAME,SEX,EMAIL,
创建视图 视图包含应用的 HTML 代码,并将应用的控制器逻辑和表现逻辑进行分离。视图文件存放在 resources/views 目录中。下面是一个简单的视图示例:
加密测试的存储过程 ? 1
简介数据库快照 数据库快照,正如其名称所示那样,是数据库在某一时间点的视图。是SQL Server在2005之后的版本引入的特性。快照
一 ,mysql事务 MYSQL中只有INNODB类型的数据表才能支持事务处理。 启动事务有两种方法 (1) 用begin,rollback,commit来实现 复制代码代码如
前言 在日常开发中,存储数据的最常用的方式便是数据库了,其中最为著名的便是MySQL数据库,因它简便易于上手而且可扩展性强大,跨平台使得它广为使用。上一篇文章,我们讲到了它的安装,今天我们就来
1、视图 视图:VIEW,虚表,保存有实表的查询结果,实际数据不保存在磁盘 物化视图:实际数据在磁盘中有保存,加快访问,MySQL不支持物化视图 基表:视图依赖的表 视图中的数据事实上
事项开启和使用 ? 1
代码如下: create PROCEDURE sp_decrypt(@objectName varchar(50)) AS begin begin tran&
前言 在之前 《Oracle打怪升级之路一》中我们主要介绍了Oracle的基础和Oracle常用查询及函数,这篇文章作为补充,主要介绍Oracle的对象,视图、序列、同义词、索引等,以及PL/SQL编
我是一名优秀的程序员,十分优秀!