jspatch的简单应用

这个是官网http://jspatch.com/
一个轻量级的热修复工具,按照官网配置一下也就那么几行代码,就可以轻松配置好。

首先建好一个工程

将下载的包拖进来


3C01E269-0462-4E26-A0BE-76FD6954FE5B.png

下面导入系统依赖库

534FF0AD-6907-4DC2-89CA-6742A2DCEB3D.png

jspatch库是拖进去就会自动加载进去的

然后就是在appdelegate里面的配置

8F703DCF-58FA-4261-82C7-883E4E2F57EE.png

上面分别代表的是测试环境和正式环境,不懂得百度一下

下面就可以愉快的写代码了

p.p1 {margin: 0.0px 0.0px 0.0px 0.0px; font: 11.0px Menlo; color: #d12f1b}p.p2 {margin: 0.0px 0.0px 0.0px 0.0px; font: 11.0px Menlo; min-height: 13.0px}p.p3 {margin: 0.0px 0.0px 0.0px 0.0px; font: 11.0px Menlo; color: #4f8187}p.p4 {margin: 0.0px 0.0px 0.0px 0.0px; font: 11.0px Menlo; color: #008400}p.p5 {margin: 0.0px 0.0px 0.0px 0.0px; font: 11.0px Menlo; color: #bb2ca2}p.p6 {margin: 0.0px 0.0px 0.0px 0.0px; font: 11.0px Menlo}p.p7 {margin: 0.0px 0.0px 0.0px 0.0px; font: 11.0px Menlo; color: #3d1d81}p.p8 {margin: 0.0px 0.0px 0.0px 0.0px; font: 11.0px Menlo; color: #703daa}span.s1 {font-variant-ligatures: no-common-ligatures; color: #78492a}span.s2 {font-variant-ligatures: no-common-ligatures}span.s3 {font-variant-ligatures: no-common-ligatures; color: #bb2ca2}span.s4 {font-variant-ligatures: no-common-ligatures; color: #000000}span.s5 {font-variant-ligatures: no-common-ligatures; color: #703daa}span.s6 {font-variant-ligatures: no-common-ligatures; color: #3d1d81}span.s7 {font-variant-ligatures: no-common-ligatures; color: #272ad8}span.s8 {font-variant-ligatures: no-common-ligatures; color: #d12f1b}span.s9 {font: 11.0px 'PingFang SC'; font-variant-ligatures: no-common-ligatures; color: #d12f1b}

#import "ViewController.h"

@interface ViewController ()
/**
 *  <#Description#>
 */
@property(nonatomic,strong)NSArray *array;
@end

@implementation ViewController

- (void)viewDidLoad {
    [super viewDidLoad];
    
    UIButton *btn = [UIButton buttonWithType:UIButtonTypeCustom];
    btn.frame = CGRectMake(100, 100, 200, 50);
    
    [btn setTitle:@"触发崩溃事件" forState:UIControlStateNormal];
    
    btn.backgroundColor = [UIColor redColor];
    
    [btn addTarget:self action:@selector(bugEvent) forControlEvents:UIControlEventTouchUpInside];
    
    [self.view addSubview:btn];

}

-(void)bugEvent{
    
    NSArray *arr = [NSArray array];
    
    NSString *str = arr[10];
    
    
}

@end

这个就会触发一个数组越界的错误

有人会说这么简单改一下不就好了,但是假如这个项目上线了呢?

所用用户因为这么一个小的错误全部闪退,体验效果肯定很差了

这个时候jspatch就应运而生了

首先我们创建一个main.js文件

A7C6AFEC-19B4-4AB0-9C76-FDCB3F9C5802.png
748DC448-637A-41E5-ACCB-0E7B3FBEAC07.png

打开这个文件

8BC27868-F65C-4242-95D8-1CEDD97AE375.png

下面我们开始编写代码了


defineClass('ViewController', {
            
            bugEvent:function() {
            
            var array = NSArray.arrayWithObjects("as", "ss", null);
            
            var str = array().objectAtIndex(1);
            
            console.log(str);
            },

            })

再次运行就不会崩溃了

什么!这么写很费劲,没问题我给你提供两种方案
*http://bang590.github.io/JSPatchConvertor/ 这个可以将oc代码转换成js代码
什么,打开网页比较慢,们问题还有

590EAAE3-35D5-4945-8BB7-8CA622F02F86.png

这个是代码提示插件,找不到的自行百度一下

这个是线下测试下面就是线上测试

我们新建一个项目


DD202A99-EF6C-4999-8D45-806544DC7D64.png

我们打开它

A3C4CA94-7433-4ED9-B329-C84BF3E08039.png

点击添加app版本输入你目前app的版本号

1263CFA7-FF68-463A-8914-EA20250736D3.png

点击打开

7D41410E-8A7E-4A5A-B4D2-6C611293ADBF.png

选中你的main.js文件进行上传,简单吧。模拟测试记得把DEBUG改成release

E11CA280-8356-40A4-B2E7-1134DF4138CE.png

就这么多吧,就是一个简单的入门的小应用,欢迎大家指正。

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

推荐阅读更多精彩内容

  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,580评论 18 139
  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 171,392评论 25 707
  • Spring Boot 参考指南 介绍 转载自:https://www.gitbook.com/book/qbgb...
    毛宇鹏阅读 46,724评论 6 342
  • StringIO StringIO顾名思义就是在内存中读写str。要把str写入StringIO,我们需要先创建一...
    牛崽儿酷阅读 205评论 0 0
  • JSon实体类快速生成插件 GsonFormat 1.2.2 http://www.jianshu.com/p/b...
    jerryhigh阅读 172评论 0 0