iOS客户端动态配置与组件化

现在客户端的功能越开发越大,功能点越多,功能点入口也很多,通过动态配置可以每个功能或页面进行解耦,方便控制开启与关闭,通过动态配置也可以减少App版本升级带来的很多兼容性问题。在项目上线前把项目基础功能点通过路由注册好,方便在App中和网页中操作。针对新版本新功能,旧版本没办法使用的情况,可以更加友好的提示用户升级版本或者设置网页入口给用户提供简易入口。
通过路由可以在原生页面中、H5中、扫码、URL Scheme打开对应页面,入口统一方便维护。

一、组件化

使用路由配置页面,通过路由中注册路径与参数打开对应的页面。
注册页面建议使用protocol://path/path?params=URL编码内容
例如:appscheme://demo/page1?dataJSON=%7B%22showType%22%3A%201%7D

常用三方工具类

组件化页面

  • 普通功能页面
  • WebView
  • 跨平台页面(uni-app)
  • 支付页面
  • 404页面
  • 其他自定义页面

组件化功能

  • 关闭当前页(pop/dismiss)
  • 分享弹窗
  • 支付弹窗
  • 不支持路径提示下载最新版本
  • 打开微信,支付宝小程序
  • 打开导航弹窗(苹果地图,高德地图,百度地图,腾讯地图)
    • xcode配置qqmap://
    • xcode配置iosamap://
    • xcode配置baidumap://
  • token等基本信息失效(例如:让App退到登录页)
  • openURL
    • 发短信
    • 打电话
    • 地图
    • 邮件
  • alter
  • actionSheet

二、URL Scheme

自定义配置项目URL Scheme, 需要再项目配置->TARGETS->info->URL Types中添加一项并填入

键名 说明 示例
Identifier 项目bundleId com.xxx.xxx
URL Scheme App专属标识 AliPay

可以通过在浏览器中测试,例如AppScheme://如果可以打开App,即说明配置成功。

使用SceneDelegate获取路径与参数

App未启动时

- (void)scene:(UIScene *)scene willConnectToSession:(UISceneSession *)session options:(UISceneConnectionOptions *)connectionOptions {
    dispatch_after(dispatch_time(DISPATCH_TIME_NOW, (int64_t)(0.5 * NSEC_PER_SEC)), dispatch_get_main_queue(), ^{
        [connectionOptions.URLContexts enumerateObjectsUsingBlock:^(UIOpenURLContext * _Nonnull obj, BOOL * _Nonnull stop) {
            // TODO: 获取到链接`obj.URL`打开对应Router
        }];
    });
}

App已启动

- (void)scene:(UIScene *)scene openURLContexts:(NSSet<UIOpenURLContext *> *)URLContexts {
    [URLContexts enumerateObjectsUsingBlock:^(UIOpenURLContext * _Nonnull obj, BOOL * _Nonnull stop) {
        // TODO: 获取到链接`obj.URL`打开对应Router
    }];
}

使用AppDelegate获取路径与参数

App未启动时

- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions {
    dispatch_after(dispatch_time(DISPATCH_TIME_NOW, (int64_t)(0.5 * NSEC_PER_SEC)), dispatch_get_main_queue(), ^{
        // TODO: 获取到链接`launchOptions[UIApplicationLaunchOptionsURLKey]`打开对应Router
    });
    return YES;
}

App已启动

- (BOOL)application:(UIApplication *)app openURL:(NSURL *)url options:(NSDictionary<UIApplicationOpenURLOptionsKey,id> *)options {
    // TODO: 获取到链接`url`打开对应Router
    return YES;
}

注意:路径打开会转成小写字母,所以请设定路径时就全部为小写字母

三、扫码

通过之前注册的路径生成二维码,扫描二维码解析路径后进行页面操作。

四、JS交互

原生页面获取网页中信息

原生页面显示样式由网页来控制,例如导航栏的样式,字体颜色,状态栏颜色,右侧按钮,导航栏是否随页面滚动,可以直接通过js触发消息通知原生页面变更样式。
通过WKUserContentController控制页面操作,实例注册两个事件styleaction,
js在网页中触发为示例:

  • 打开页面
window.webkit.messageHandlers.action.postMessage({ "url": "appscheme://demo/page1" });
  • 弹窗效果
window.webkit.messageHandlers.action.postMessage({ "url": "appscheme://xxx/xxx?dataJSON=%7B%22type%22%3A%202%7D" });

  • 设置样式
window.webkit.messageHandlers.style.postMessage({
    "showNavigationBar": true,
    "scrollNavigationBar": false,
    "backgroundColor": "#FF333333",
    "barTinColor": "#ffffffff",
    "statusBarBlack": true,
    "rightButtons": [
       {
          "text": "分享",
          "icon": "https://abc.xxx.com/img/icon.png",
          "action": "appSchema/path/path"
       },
       {
          "text": "举报",
          "icon": "https://abc.xxx.com/img/icon.png",
          "action": "appSchema/path/path"
       }
    ],
    "notSupportGesture": true,
    "notSupportBounces": true
});

Action

  • 关闭网页
  • 控制原生样式
  • 打开原生页面
  • 打开弹窗
  • 打开支付
  • 打开分享

Style

  • 是否显示导航栏
  • 导航栏是否随页面滚动
  • 导航栏颜色
  • 状态栏颜色
  • 文字和按钮颜色
  • 右侧按钮内容与点击操作
  • 是否支持手势返回,默认支持
  • 是否支持上下回弹效果,默认iOS支持
{
  "showNavigationBar": true, // 是否显示导航栏
  "scrollNavigationBar": true, // 导航栏是否随页面滚动,默认透明然后滚动显示颜色
  "backgroundColor": "#fffffff", // 背景颜色
  "barTinColor": "#ff333333", // 标题颜色,按钮颜色
  "statusBarBlack": true, // 状态是否为黑色
  "rightButtons": [ // 右边区域按钮
    {
      "text": "分享", // 按钮文本呢
      "icon": "https://abc.xxx.com/img/icon.png", // 按钮图标
      "action": "appSchema/path/path" // 按钮点击操作
    },
    {
      "text": "举报", // 按钮文本呢
      "icon": "https://abc.xxx.com/img/icon.png", // 按钮图标
      "action": "appSchema/path/path" // 按钮点击操作
    }
  ],
  "notSupportGesture": false, // 是否不支持手势返回
  "notSupportBounces": false // 是否不支持回弹效果
}

网页获取原生信息

网页中可能需要原生App提供一个基本信息,例如

  • App版本
  • App渠道(iOS、Android)
  • 用户token等基本信息

Demo地址:点击前往

最后编辑于
?著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,100评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,308评论 3 388
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事?!?“怎么了?”我有些...
    开封第一讲书人阅读 159,718评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,275评论 1 287
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,376评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,454评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,464评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,248评论 0 269
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,686评论 1 306
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,974评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,150评论 1 342
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,817评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,484评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,140评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,374评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,012评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,041评论 2 351

推荐阅读更多精彩内容