AppleWatch开发入门三——代码交互与控制器生命周期

简介: AppleWatch开发入门三——代码交互与控制器生命周期

AppleWatch开发入门三——代码交互与控制器生命周期


一、引言


       在前两篇博客中,讨论了关于watch开发中框架与界面布局相关,然而主要的逻辑,终究还是要通过代码来实现的,在我们创建了项目之后,就会生成InterfaceController这个文件,它就是我们storyBoard中的入口视图控制器。


二、代码交互与控制器声明周期


       storyBoard中的控件我们可以通过拖拽的方式关联到文件中,Action和Outlet两种关联方式基本可以达到我们修改控件和处理业务逻辑的需求。


       WKInterfaceController类似于iOS中的ViewController,是watch中主要用于展示界面的controller,我们的控件也都是基于这个容器中显示。在模板中,系统为我们提供了三个函数,这三个函数体现了watch一个界面的声明周期,如下:


   //这个函数在初始化界面时会触发,通过context可以实现界面的传值

   override func awakeWithContext(context: AnyObject?) {

       super.awakeWithContext(context)

 

   }

   //这个函数在界面即将展现时触发 类似于iOS中的ViewWillApear

   override func willActivate() {

       // This method is called when watch view controller is about to be visible to user

       super.willActivate()

   }

   //这个函数在界面消失后触发,类似于iOS中的ViewDidDisAppear

   override func didDeactivate() {

       // This method is called when watch view controller is no longer visible

       super.didDeactivate()

   }

三、watch中的界面跳转与传值


       与iOS类似,watchOS的界面跳转也有两种方式:model和push。同样,我们也可以通过storyBoard或者代码来进行跳转。


1、通过代码跳转与传值


       我们创建两个InterfaceController,界面如下:

image.png



通过代码跳转,我们需要给第二个controller设置一个id标识符:


image.png


在按钮触发的方法中,如下跳转:


@IBAction func `switch`(value: Bool) {

        //这里的context是传值的上下文

        //在awakeWithContext方法中会将这个值取到

       pushControllerWithName("InterfaceControllerTwo", context: "我是传的值")

   }

2、在storyBoard中设置跳转关系


       我们也可以直接在storyBoard中设置界面的跳转,按住control,拖拽按钮到要跳转的controller,会出现push和model菜单,选择后,当我们触发按钮方法时,就会跳转。



通过这种方式进行的跳转,在执行跳转之前,会执行如下这个函数:


override func contextForSegueWithIdentifier(segueIdentifier: String) -> AnyObject? {

       return "我是值"

   }

目录
相关文章
|
5月前
|
存储 运维 前端开发
中后台前端开发问题之定义编排对象如何解决
中后台前端开发问题之定义编排对象如何解决
31 0
|
6月前
|
Java 测试技术 开发者
开发与运维组件问题之开发组件的时候,对于插槽中需要使用到组件上下文的情况如何解决
开发与运维组件问题之开发组件的时候,对于插槽中需要使用到组件上下文的情况如何解决
|
8月前
|
前端开发 安全 开发工具
前端场景的代码部署方式都有那些?
【4月更文挑战第17天】本文分析了四种常见的前端代码部署方式:FTP/SFTP、Git、Docker和云服务平台部署。FTP/SFTP简单易用但效率低;Git提供版本控制,适合自动化部署,但有学习成本;Docker确保环境一致性,高效扩展,但较复杂;云服务平台弹性伸缩,高可用,但可能产生依赖和成本。选择部署方式应综合考虑项目需求、技术能力和成本。
230 0
|
JavaScript 小程序
UniApp 小程序封装原生组件(使用与交互详细流程)
UniApp 小程序封装原生组件(使用与交互详细流程)
462 0
jira学习案例70-状态提升,组合组件和控制反转3
jira学习案例70-状态提升,组合组件和控制反转3
77 0
jira学习案例70-状态提升,组合组件和控制反转3
jira学习案例68-状态提升,组合组件和控制反转1
jira学习案例68-状态提升,组合组件和控制反转1
73 0
jira学习案例68-状态提升,组合组件和控制反转1
|
中间件
基于Gin封装Web框架 - 7. 控制器优化 - 更好用的控制器模式
基于Gin封装Web框架 - 7. 控制器优化 - 更好用的控制器模式
495 0
基于Gin封装Web框架 - 7. 控制器优化 - 更好用的控制器模式
|
编解码 前端开发 数据处理
前端基础向--从项目入手封装公共组件
前端基础向--从项目入手封装公共组件
320 0
|
JavaScript 前端开发 API
ReactJS 101:构建可重用组件、管理状态和创建实际应用程序的初学者指南
ReactJS 101:构建可重用组件、管理状态和创建实际应用程序的初学者指南
181 0
|
前端开发
前端工作小结77-新的封装组件
前端工作小结77-新的封装组件
92 0
前端工作小结77-新的封装组件