IOS中Hybird中数据驱动与脚本驱动的实现

时间:2022-12-13 20:53:02

现在Hybird这块,网上也有很多文章,最近研究了下,分享给大家。

什么是Hybird技术?

1、一般是指WebView和Native技术混合而成的一套技术方案

2、也可以理解成,非Native技术与Native技术的混合开发

现在的Hybird有几种实现方式:

1、UIWebView、WKWebView 直接使用的是网页与OC交互(cordova与phonegap是使用该方案)(本文没有对该方案进行讲解)

2、数据驱动、脚本驱动(RN、微信小程序用的好像都是这种原理)

现在对于使用了webView实现的hybird技术大家都知道它的优势与劣势

优势是 可以热更新,直接WEB前端人员也能开发,擅长复杂的内容排版

劣势是 体验没有原生应用流畅

本文重点是说 数据驱动、脚本驱动,好处是能热更新,体验也更好,因为它都是生成原生应用,和WebView完全不一样

什么是数据驱动?

数据驱动说的是 我们App通过下载服务器端的json文件(里面定义了我们的UI布局样式,简单的业务功能)然后本地解析动态创建相应的UI。

什么是脚本驱动?

脚本驱动说的是 通过OC中的JavaScriptCore实现JS与OC的交互,一些简单的功能能放到JS中处理。

效果演示

默认打开效果:IOS中Hybird中数据驱动与脚本驱动的实现

点击测试1按钮的效果:IOS中Hybird中数据驱动与脚本驱动的实现

点击测试2按钮的效果:IOS中Hybird中数据驱动与脚本驱动的实现

以上的这些UI布局及功能都是动态写在 json与js 文件里面的

具体代码演示

因为我们为了方便演示,我这里没有搭建WEB服务器,所以json文件就直接放在APP里面,我们先创建 page.json 和 page.js 文件

分别如下:

IOS中Hybird中数据驱动与脚本驱动的实现

可以看得出来,我们这个json文件里面的数据定义了一些UI的相关属性,注意button里面的那个onClicked,对应的是下面page.js里面的js方法

IOS中Hybird中数据驱动与脚本驱动的实现

这里面的 updateLabelText 方法是我们App里面定义好的,下面我们来看App里

//
// ViewController.m
// hybirdDemo
//
// Created by xgao on 17/3/3.
// Copyright © 2017年 xgao. All rights reserved.
// #import "ViewController.h"
//@import JavaScriptCore;
#import <JavaScriptCore/JavaScriptCore.h> // 数据驱动、脚本驱动
@interface ViewController () // 用于执行JS的上下文
@property (nonatomic,strong) JSContext* jsContext;
// 保存按钮的点击事件的方法名
@property (nonatomic,retain) NSMutableDictionary* functionDic; @end @implementation ViewController - (void)viewDidLoad {
[super viewDidLoad]; [self initDataUI];
[self initJSContext];
} - (NSMutableDictionary*)functionDic{
if (!_functionDic) {
_functionDic = [NSMutableDictionary dictionary];
}
return _functionDic;
} - (void)initDataUI{ // 加载JSON数据
NSString* pageJsonPath = [[NSBundle mainBundle] pathForResource:@"page" ofType:@"json"];
NSData* pageJsonData = [NSData dataWithContentsOfFile:pageJsonPath];
NSDictionary* pageJsonDic = [NSJSONSerialization JSONObjectWithData:pageJsonData options:NSJSONReadingAllowFragments error:nil]; NSArray<NSDictionary*>* views = pageJsonDic[@"views"];
for (NSDictionary* view in views) {
// 解析UI
if ([view[@"class"] isEqualToString:@"label"]) { // UILabel UILabel* label = [[UILabel alloc]initWithFrame:[self CGRectWithDic:view]];
label.text = view[@"text"];
label.tag = [view[@"tag"] intValue];
[self.view addSubview:label];
}else if([view[@"class"] isEqualToString:@"button"]){ // UIButton UIButton* button = [[UIButton alloc]initWithFrame:[self CGRectWithDic:view]];
[button setTitle:view[@"title"] forState:UIControlStateNormal];
button.tag = [view[@"tag"] intValue];
[button setTitleColor:[UIColor greenColor] forState:UIControlStateNormal];
[button addTarget:self action:@selector(buttonClick:) forControlEvents:UIControlEventTouchUpInside];
// 添加到事件字典中,btnClick
[self.functionDic setObject:button forKey:view[@"onClicked"]];
[self.view addSubview:button];
}
}
} // 初始化JSContext
- (void)initJSContext{ self.jsContext = [[JSContext alloc]init]; // 加载 page.js 脚本文件
NSString* pageJsPath = [[NSBundle mainBundle] pathForResource:@"page" ofType:@"js"];
NSString* pageJs = [NSString stringWithContentsOfFile:pageJsPath encoding:NSUTF8StringEncoding error:nil];
// 执行JS脚本,将JS代码注入到 上下文中
[self.jsContext evaluateScript:pageJs]; // 定义updateLabelText方法,用于JS调用OC
__weak ViewController* weakSelf = self;
self.jsContext[@"updateLabelText"] = ^(NSString* text,NSInteger tag){
UILabel* label = [weakSelf.view viewWithTag:tag];
label.text = text;
};
} // button按钮点击通用事件
- (void)buttonClick:(UIButton*)button{ for (NSString* func in self.functionDic.allKeys) {
UIButton* btn = self.functionDic[func];
if ([btn isEqual:button]) {
// OC 调用 JS 方法,这里就是 OC调用JS定义的那两个 btnClick 和 btnClick2
[self.jsContext[func] callWithArguments:nil];
break;
}
} } #pragma mark - Private - (CGRect)CGRectWithDic:(NSDictionary*)dic{ CGFloat x = [dic[@"x"] floatValue];
CGFloat y = [dic[@"y"] floatValue];
CGFloat width = [dic[@"width"] floatValue];
CGFloat height = [dic[@"height"] floatValue];
return CGRectMake(x, y, width, height);
} @end

IOS中Hybird中数据驱动与脚本驱动的实现的更多相关文章

  1. IOS中Hybird实现

    现在Hybird这块,网上也有很多文章,最近研究了下,分享给大家. 什么是Hybird技术? 1.一般是指WebView和Native技术混合而成的一套技术方案 2.也可以理解成,非Native技术与 ...

  2. unity导出工程导入到iOS原生工程中详细步骤

    一直想抽空整理一下unity原生工程导入iOS原生工程中的详细步骤.做iOS+vuforia+unity开发这么长时间了.从最初的小小白到现在的小白.中间趟过了好多的坑.也有一些的小小收货.做一个喜欢 ...

  3. iOS原生项目中集成React Native

    1.本文的前提条件是,电脑上已经安装了CocoaPods,React Native相关环境. 2.使用Xcode新建一个工程.EmbedRNMeituan [图1] 3.使用CocoaPods安装Re ...

  4. iOS 开发者旅途中的指南针 - LLDB 调试技术

    文章转载于:iOS 开发者旅途中的指南针 - LLDB 调试技术 今天给大家介绍的内容,无关乎任何功能性开发技术,但又对开发的效率影响至深,这就是调试技术. 何为调试呢,比如我们用 print 函数在 ...

  5. 在iOS应用程序中使用Frida绕过越狱检测

           阿里聚安全在之前的三篇博客中介绍了利用Frida攻击Android应用程序,整个过程仿佛让开发者开启上帝视角,在本篇博客中,我们将会介绍在iOS应用程序中使用Frida绕过越狱检测.即使 ...

  6. iOS应用发布中的一些细节

    iOS应用发布中的一些细节 前言 这几天最大的新闻我想就是巴黎恐怖袭击了,诶,博主每年跨年都那么虔诚地许下“希望世界和平”的愿望,想不到每年都无法实现,维护世界和平这么难,博主真是有心无力啊,其实芸芸 ...

  7. Firebug中调试中的js脚本中中文内容显示为乱码

    Firebug中调试中的js脚本中中文内容显示为乱码 设置 页面 UFT-8 编码没用, 解决方法:点击 "Firebug"工具栏 中的"选项"---&quot ...

  8. iOS 解决LaunchScreen中图片加载黑屏问题

    iOS 解决LaunchScreen中图片加载黑屏问题 原文: http://blog.csdn.net/chengkaizone/article/details/50478045 iOS 解决Lau ...

  9. iOS开发 Xcode8中遇到的问题及改动

      iOS开发 Xcode8中遇到的问题及改动 新版本发布总会有很多坑,也会有很多改动. 一个一个填吧... 一.遇到的问题 1.权限以及相关设置 iOS10系统下调用系统相册.相机功能,或者苹果健康 ...

随机推荐

  1. 【转】FlashBack总结之闪回查询与闪回表

    本文主要介绍利用UNDO表空间的闪回技术,主要包括:闪回表,闪回版本查询,闪回事务查询,闪回查询.这些闪回技术实现从回滚段中读取表中一定时间内操作过的数据,可用来进行数据比对,或者修正意外提交造成的错 ...

  2. 如何把android中布局文件&lpar;&period;xml&rpar;与相关的类&lpar;&period;java&rpar;进行关联?

    eg:把一个布局文件名为page1.xml与MainActivity.java(工程自动生成)进行 1.在存放使用资源的res文件夹下的layout文件夹内新建一个XML布局文件,如命名为:page1 ...

  3. phpcms首页调用会员头像及金钱、积分等信息,并按照积分点数排列

    <div class="box"> <h5>最新会员</h5> <div class="col-auto">&l ...

  4. loadRunner 11&period;0 安装及破解

    http://jingyan.baidu.com/article/20095761b31b58cb0621b463.html 破解时必须是管理员账户登录.

  5. hdu&lowbar;5794&lowbar;A Simple Chess&lpar;lucas&plus;dp&rpar;

    题目链接:hdu_5794_A Simple Chess 题意: 给你n,m,从(1,1)到(n,m),每次只能从左上到右下走日字路线,有k(<=100)的不能走的位置,问你有多少方案 题解: ...

  6. TCP&sol;IP协议精华笔记

    1.简介 TCP/IP协议并非单指TCP协议.IP协议,它是一组包括TCP协议和IP协议,UDP(User Datagram Protocol)协议.ICMP(Internet Control Mes ...

  7. LKD&colon; Chapter 7 Interrupts and Interrupt Handlers

    Recently I realized my English is still far from good. So in order to improve my English, I must not ...

  8. EOS 的世界里可能再也没有小偷了

    EOS 针对以下两种情况设计了应急措施: 1. 账户被盗(私钥被盗或有权限的其他账户被盗) 2. 账户遗失(私钥遗失或有权限的其他账户遗失) ## 1.账户被盗 EOS 有可能会强制要求所有账户的 O ...

  9. js获取当前有效样式

      js获取有效样式   节点.currentStyle["属性名"]        兼容ie方法(只有ie有效) getcomputedStyle(节点)["属性名&q ...

  10. 基于jquery判断浏览器版本过低代码

    基于jquery判断浏览器版本过低代码.这是一款对不支持HTML5跟CSS3代码的浏览器提示用户更换特效代码.效果图如下: 在线预览   源码下载 实现的代码. html代码: <div sty ...