JSPatch的使用

作者: Sunxb | 来源:发表于2016-06-03 14:56 被阅读991次

    JSPatch 是一个 iOS 动态更新框架,只需在项目中引入极小的引擎,就可以使用 JavaScript 调用任何 Objective-C 原生接口,获得脚本语言的优势:为项目动态添加模块,或替换项目原生代码动态修复 bug。


    因为还要部署线上的js文件,所以直接用JSPatch SDK,该平台可以帮助管理补丁文件,加密等
    点击去JSPatch平台注册
    根据文档的提示把SDK集成进自己的项目,文档讲的很详细,此处略


    具体代码

    1. 导入 #import <JSPatch/JSPatch.h>

    2. 在上线之前需要对脚本进行本地测试,看看运行是否正常。SDK 提供了方法 +testScriptInBundle 用于发布前的测试:
      注意在 JSPatch 平台的规范里,JS脚本的文件名必须是main.js

    - (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions {
        [JSPatch testScriptInBundle];//为了线下测试js文件的可用性,线上代码是不同的,下面有写
     }    
    

    调用这个方法后,JSPatch 会在当前项目的 bundle 里寻找 main.js 文件执行,效果与最终线上用户下载脚本执行一样,测试完后就可以准备上线这个脚本。

    示例图1

    下面是重点 -- js文件中写什么

    举个例子吧,下面是我的某一个控制中的代码
    #import "JPViewController.h"

    @interface JPViewController ()
    {
     
    }
    @end
    
    @implementation JPViewController
    
    - (void)viewDidLoad {
        [super viewDidLoad];
        self.view.backgroundColor = [UIColor whiteColor];
        [self loadButton];
        // Do any additional setup after loading the view.
    }
    
    - (void)loadButton {
         UIButton *tipBtn = [[UIButton alloc] initWithFrame:CGRectMake(10, 50, 200, 30)];
        [tipBtn setTitleColor:[UIColor redColor] forState:UIControlStateNormal];
        [tipBtn setTitle:@"hello_jspatch" forState:UIControlStateNormal];
        [tipBtn addTarget:self action:@selector(clickedBtn:) forControlEvents:UIControlEventTouchUpInside];
        [self.view addSubview:tipBtn];
        
    }
    
    - (void)clickedBtn:(UIButton *)sender {
        sender.backgroundColor = [UIColor redColor];
    }
    
    
    @end
    

    页面上有一个按钮,文字为"hello_jspatch",点击事件是让自己的背景颜色变为红色
    假设这是我线上的版本,但这是有错误的,我的文字不应该是"hello_jspatch",应该是"success_jspatch",点击事件不该是变红而是变绿色
    (这时我们就可以通过JSPatch热更新,具体原理不解释.)
    利用运行时特性处理这个控制器中的loadButtonclickedBtn:这两个方法
    js文件中的语法不会?不要紧,JSPatch的作者还有一个开源项目,直接把我们需要的oc代码转为需要的js

    这里是链接--JSPatchConvertor

    示例图2

    把我们需要更改的两处代码, 改为"succcess_jspatch"和greenColor()


    注意

    现在的代码也不一定是一定能用的,因为JSPatch作者对语法做了一些规定,有好多地方这个转换器并不能帮助完美的转换
    这就要去github中看具体的规定
    点此跳转到github--JSPatch-Wiki

    下面附上修改完的代码

    require('UIButton,UIColor');
    defineClass('JPViewController', {
        loadButton: function() {
            var tipBtn = UIButton.alloc().initWithFrame({x:10, y:50, width:200, height:30});
            tipBtn.setTitleColor_forState(UIColor.redColor(), 0);
            tipBtn.setTitle_forState("success_jspatch", 0);
            tipBtn.addTarget_action_forControlEvents(self, "clickedBtn:", 1<<6);
            self.view().addSubview(tipBtn);
    
        },
        clickedBtn: function(sender) {
            sender.setBackgroundColor(UIColor.greenColor());
        }
    });
    

    ** 我修改了1. initWithFrame后面的CGRectMake()的样式 2. UIControlStateNormal UIControlEventTouchUpInside 这类枚举改为对应枚举值 这在Wiki中都是有提到的,一定要仔细看**

    现在就可以运行了~~~~(但是不要忘了,咱们这是在线下测试呢)

    线上的版本appdelegate中是这样的才对

    - (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions {      
        [JSPatch startWithAppKey:@"你自己的appkey"];//JSPatch SDK 平台上添加应用得到的key
        [JSPatch sync];
        //自动去平台下载补丁包
    }
    

    最后,把那个js文件传到平台就ok了,注意版本号

    示例图3

    注:还有一些安全问题,大家可以根据SDK文档研究一下

    文中有不对的地方希望可以提出,一起进步

    相关文章

      网友评论

      • 田空Sky2000:楼主 我的一个getter方法 出了问题 但是使用代码转换器 转换后直接不行了,你有修改getter方法的相关经验吗
        Sunxb:@田空Sky2000 上线不会被拒?有风险吧
        田空Sky2000:@Sunxb 对啊
        Sunxb:@田空Sky2000 现在还在用jspatch?
      • 微笑了:请问这个页面[self.navigationController pushViewController:[[hhh alloc]init] animated:YES];在转换成js以后跳转不执行是什么原因?求指导
        Sunxb:@微笑了 可能是语法写的有点问题。最好上点代码
        微笑了:@Sunxb 同一个方法中的其他内容已经执行了,就是这个跳转的不执行
        Sunxb:@微笑了 有没有先测一下js中那一个语录执行了没有
      • 尤先森:楼主,请问如果要测试线上版本是不是必须上线的项目??
        Sunxb:@尤鸿斌 文件里的main.js是为了测试用的,你那个加载本地还是线上的方法改掉了吗?
        尤先森:@Sunxb 那在程序的文件里面需要有main.js吗?测试的我是用着没问题了。现在用线上的好像没反应
        Sunxb:@尤鸿斌 应该是不需要上线的项目,只要保证线上的环境拉到线上环境对应的补丁包就可以
      • 44d3387e09f3:楼主,我想请问一下swift 也可以用这个东西吗?
        Sunxb:@Marcello_Gong 我记得从JSPatch作者的博客里面看到,应该是可以调用swift的方法,不过按照swift的规则,defineClass的类名变成'项目名.类名'
      • ShowMeCode:兄弟,报错这个request success {
        error = "Document not found";
        }
        遇到过没?
        Sunxb:@ShowMeCode 这个意思应该是没有找到你的那个文件吧
      • dcf359525293:感谢 我试试 加油
        Sunxb:@太阳下的叶子 客气了:smile:

      本文标题:JSPatch的使用

      本文链接:https://www.haomeiwen.com/subject/qwzkdttx.html