什么是JSPatch
JSPatch 是一個(gè)開源項(xiàng)目(Github鏈接),只需要在項(xiàng)目里引入極小的引擎文件旭绒,就可以使用 JavaScript 調(diào)用任何 Objective-C 的原生接口糠悯,替換任意 Objective-C 原生方法洋满。目前主要用于下發(fā) JS 腳本替換原生 Objective-C 代碼孝赫,實(shí)時(shí)修復(fù)線上 bug拱撵。
理解下來(lái)類似于運(yùn)行時(shí)的Method Swizzling辉川,動(dòng)態(tài)地將需要修復(fù)的bug代碼替換成更新的代碼。不同的是JSPatch使用JavaScript來(lái)進(jìn)行熱修復(fù)拴测,可以在App上線的狀態(tài)下替換App內(nèi)的JS文件從而可以隨心所欲修改和替換原有的方法,達(dá)到熱修復(fù)的效果府蛇。
JSPatch的使用
Github項(xiàng)目主頁(yè)上介紹可以通過(guò)pod導(dǎo)入的方式加入項(xiàng)目集索,手動(dòng)管理也僅僅是需要添加三個(gè)文件到項(xiàng)目既可使用。
Installation
CocoaPods
CocoaPods is a dependency manager for Objective-C, which automates and simplifies the process of using 3rd-party libraries like JSPatch in your projects. See the "Getting Started" guide for more information.
# Your Podfile
platform :ios, '6.0'
pod 'JSPatch'
Manually
Copy JSEngine.m
JSEngine.h
JSPatch.js
in JSPatch/ to your project.
使用JS調(diào)用原生API的的JS語(yǔ)法在項(xiàng)目主頁(yè)上也有文檔。
其中最關(guān)鍵的就是這個(gè)API:
defineClass(classDeclaration, [properties,] instanceMethods, classMethods)
@param classDeclaration: 字符串务荆,類名/父類名和Protocol
@param properties: 新增property妆距,字符串?dāng)?shù)組,可省略
@param instanceMethods: 要添加或覆蓋的實(shí)例方法
@param classMethods: 要添加或覆蓋的類方法
例子:
defineClass('JPViewController', {
handleBtn: function(sender) {
//self.ORIGhandleBtn()
var tableViewCtrl = JPTableViewController.alloc().init()
self.navigationController().pushViewController_animated(tableViewCtrl, YES)
}
})
代碼作用是:替換JPViewController
類中的 handleBtn:
方法函匕,并可以self.ORIGhandleBtn()
選擇執(zhí)行原OC中的此方法娱据,這就是修復(fù)(替換)bug代碼。
在熟悉語(yǔ)法使用的過(guò)程中主要(暫時(shí))遇到了如下幾個(gè)問(wèn)題(比較容易犯錯(cuò)):
- OC中的
self.view
和self.navigationController
之類在這里都需要調(diào)用它們的getter方法來(lái)達(dá)到相同效果如self.view()
- 在OC中寫慣了的
label.text = @"text"
之類都要使用setter方法label.setText("text")
- 總結(jié)上面兩條就是訪問(wèn)和賦值屬性都要通過(guò)調(diào)用方法來(lái)實(shí)現(xiàn)
- 在JS代碼中添加屬性盅惜,重寫getter方法時(shí)中剩,需要自己創(chuàng)建局部變量,不在有自動(dòng)生成的_ivar可以使用
后話:方法名不再有補(bǔ)全提示千萬(wàn)不要寫錯(cuò)了
正在繼續(xù)學(xué)習(xí)……