从启动过程讲述普元Mobile 8.0基座


?
从启动过程讲述普元Mobile 8.0基座
本文插图
转载本文需注明出处:微信公众号EAWorld , 违者必究 。
前言:
通常来讲iOS 应用启动过程有两种:一是冷启动(后台没有运行的普通启动过程)、二是热启动(后台运行没有被系统kill掉 , 重新打开能立即恢复到之前打开的状态) 。 本文着重讲普元Mobile8.0 冷启动过程 。
目录:
1.集成跨平台框架React Native
2.React Native交互原理
3.组件的集成
4.模块化
1.集成跨平台框架React Native
应用冷启动后 , 先执行main函数 , main内部会调用UIApplicationMain函数 , 此函数主要是创建了UIApplication对象和创建UIApplication的delegate对象AppDelegate 。 而应用启动必要执行的代码主要在此AppDelegate类的didFinishLaunchingWithOptions中调用 , 普通应用在此系统接口中只用初始化窗口、视图控制器添加view , makeWindowVisible就可以了 , 甚至利用StoryBoard开发页面的这部分代码也省去了 。
不过普元Mobile8.0平台是支持多平台的 , 一套前端代码运行在iOS和安卓两种系统的应用上 , 这就意味着我们接入了跨平台的明星框架React Native , 如他们官方自己介绍的一样他们最大的优点‘learn once , write anywhere’ 。
从启动过程讲述普元Mobile 8.0基座
本文插图
不同于其他热门跨平台框架 (Cordova、AppCan、Phonegap等) , 这些框架都是在iOS组件webview上进行渲染 , 或者说wkwebview(iOS 9之后) , 性能局限于webview的性能 , 缓存过大时很容易卡顿 , 就像浏览器那样 。 而RN就是利用JS控制iOS原生组件(JS桥接加Native桥接)渲染屏幕 , 和原生应用一样具有先天优势 。
既然接入了RN框架8.0的didFinishLaunchingWithOptions中主要涉及到下面三部分模块 。

  1. 安全通道
  2. RN初始化
  3. 组件和工具类注册 , 安装
官方RN Demo应用的欢迎页面:
从启动过程讲述普元Mobile 8.0基座
本文插图
2.React Native交互原理
一、安全通道通过处理调试或非调试模式下配置的server信息 , 获取安全通道数据握手成功后进行本地存储 , 便于RN接口调用进行调试 。
二、初始化RN入口导航控制器(关于RN部分代码普元Mobile8.0将其从主项目分离出主项目 , 与主项目进行模块化组合 , 便于开发的灵活性同时降低代码耦合度) 。
navgationController = [[RNRoot shareInstance] registRnRootWithLaunchOptions:launchOptions jsCodeLocation:nil];RNRoot是组件化封装的一个类 , 专门处理RN初始化的一些代码 。 (需要注意的是React Native 与 Hybrid 完全没有关系 , 它只不过是以 JavaScript 的形式告诉 Objective-C 该执行什么代码)
  1. 上面提供了jsCodeLocation接口便于提供JSbudle调试地址
  2. 主bundle、微应用包拷贝、微应用包解压
  3. 调试模式启动热部署服务
  4. 初始化RCTBridge、RCTRootView (RCTRootView将React Natvie视图封装到原生组件中 。 用户能看到的一切内容都来源于这个RootView , 所有的初始化工作也都在这个方法内完成)

从启动过程讲述普元Mobile 8.0基座
本文插图
- (instancetype)initWithBundleURL:(NSURL *)bundleURLmoduleName:(NSString *)moduleNameinitialProperties:(NSDictionary *)initialPropertieslaunchOptions:(NSDictionary *)launchOptions此接口内部会创建一个RCTBridge实例 , 这个实例就是实现OC与JS沟通的桥梁 , 具体实现要在RCTBatchedBridge 类中的 start方法内, start中执行了重要的初始化任务,基于大量的GCD实现了异步初始化组件框架的任务 。


推荐阅读