JSPatch为我们iOS开发带来了一个新的迭代更新方式,使我们应用开发人员可以像手游一样在线修复代码,进行功能升级。
熟悉JSPatch原理的朋友的应该知道,热更新是基于Objective-C(以下简称oc)语言的动态特性实现的。
我们在使用swift语言做iOS项目开发的时候,想要做实现热更新的功能就和oc有一些小小的区别了。
下面👇就是我main.js
的文件内容
require("UIColor,UIViewController, NSData, NSURLSession, NSString, NSString,UIView");
defineClass("XY000test.QHomeViewController", {
viewssssssssDidLoad: function() {
// self.super().viewDidLoad();
var view = self.mainTableView();
var redColor = UIColor.redColor();
// view.setBackgroundColor(redColor);
},
toFavoriteEditAction:function(){
self.navigationController().showViewController_sender(NewViewController.new(), null);
console.log("JS解析 我就不信了");
}
});
defineClass('NewViewController: UIViewController',{
viewDidLoad:function(){
self.super().viewDidLoad();
self.view().setBackgroundColor(UIColor.greenColor());
}
}
)
我觉得主要有以下几个点需要注意,如果有错或者不够,希望大家可以补充纠正
1、XY000test.QHomeViewController
所属类名前需要加项目文件名
2、方法的改写操作还是需要按照oc的语言风格进行转译比如self.navigationController().showViewController_sender(NewViewController.new(), null);
3、还有需要注意的就是Bool
/Enum
类型需要写成Int
/Interger
,至于在Swift 中使用GCD
我还没有尝试,不知道是不是一样的
但是,我又遇到了一个新的问题,通过swift访问原项目所在方法时,并没有效果,这是我的Swift工程文件👇
/// 我的最爱
@objc private func toFavoriteEditAction() {
let vc1 = UIStoryboard.init(name: "QMyFavoriteEditVC", bundle: nil).instantiateViewController(withIdentifier: "MyFavoriteVC") as? MyFavoriteVC
vc1?.favoritesMainModel = favoritesMainModel
navigationController?.show(vc1!, sender: nil)
}
我之前了解的情况是只要在方法前加@objc
就可以像oc一样自由的调用,目前来看并不是这样。
当然,我也找到了问题原因,需要加上dynamic
这个标签,就可以让Swift具有oc一样的Runtime
动态语言机制
/// 我的最爱
@objc dynamic private func toFavoriteEditAction() {
let vc1 = UIStoryboard.init(name: "QMyFavoriteEditVC", bundle: nil).instantiateViewController(withIdentifier: "MyFavoriteVC") as? MyFavoriteVC
vc1?.favoritesMainModel = favoritesMainModel
navigationController?.show(vc1!, sender: nil)
}
一波未平一波又起,我又遇到了一个新的问题
我们做热更新,不可能只修改UI,改一改Bug。难免会碰到网络请求,闭包回调
/// 请求接口
///
/// - Parameters:
/// - urlStr: URL请求链接
/// - parameters: 参数
/// - method: 请求方式
/// - completion: 成功回调
/// - errorCallback: 失败回调
@objc dynamic private func loadData(isNeedErrorCall:Bool = true,isNeedSid:Bool = true, urlStr:String!, parameters:[String:Any], method: HTTPMethod,completion:@escaping ((JSON)->()), errorCallback: @escaping ((Error) -> Void)){ //coding here }
Method cannot be marked @objc because the type of the parameter 5 cannot be represented in Objective-C
Method cannot be marked @objc because the type of the parameter 6 cannot be represented in Objective-C
是的,这个问题我还没有解决😭