IOS开发—JS调用OC(通过非URL的方式)

这两天真是愁,早上6点起床从老家来公司,弄得一整天脑子都只有一个字围绕着我——“困”。

本来就很匆忙的项目,雪上加霜换需求,项目里面原来通过url与javastrip交互的全换了。项目的最低系统要求提升至7.0,“JavaScriptCore”这个framework终于可以用起来,虽然我也不知道它为何物,只是听说它为JS与OC提供了很好的沟通桥梁,换句话,IOS终于可以像安卓那样与JS愉快的沟通了,但也仅仅是像,折磨我的日子是今天。

为了完成这个需求,首先我参考一些博客写了一个demo用了本地的一个html做试验,非常OK,点我看博客

当项目经理问我实现了交互没有的时候,我真的很自信的回答,demo已经写好了,应该没问题,当项目经理把我们的需求告诉我的时候,我真想抽自己一巴掌啊。我们的需求是JS先调用OC方法,把自己的一些参数传给OC,OC里面请求完成后,再把结果告诉JS。觉得很容易的大神请绕过,接下来我要讲为了这需求,我忙活了大半天,还是通过别人的代码完成的。

我们要做的有如下几件事情:

首先:通过webview加载一个本地html文件

NSString *htmlPath=[[NSBundle mainBundle] resourcePath];

htmlPath=[htmlPath stringByAppendingPathComponent:@"html/test.html"];

NSURL *localURL=[[NSURL alloc]initFileURLWithPath:htmlPath];

[self.mWebV loadRequest:[NSURLRequest requestWithURL:localURL]];

其次:我们要在我们的OC代码里面注册JS方法

- (void) h5CallApp: (NSString*) param And2: (NSString*) param2 And3: (NSString*) param3

{

NSLog(@"test with param: %@ and param2: %@ and param3: %@", param, param2,param3);

}

要保证本地的html里面有h5CallApp这个方法哦。

这就是刚刚上述博客里面提到的方法,是不是看上次很简单的样子。

But

我运用到我们项目里面的时候,死活不能调用该方法,why?我厚着脸皮问了我们的帅哥安卓开发,得知他们里面有这一样一行代码

webView.addJavascriptInterface(new JSInvoke(), "test");

看上去第一眼的感觉是不是累似注册了一个东西,可是我找了好多博客我没有找到我们IOS类似的啊,着急啊着急。

意外的意外,伟大的github上面就是资源多,我在上面找到一个EasyJSWebViewSample这样一个开源项目,里面有一句

MyJSInterface* interface = [MyJSInterface new];

[self.myWebView addJavascriptInterfaces:interface WithName:@"MyJSTest"];

是不是感觉和安卓里面的那个注册类似的,没错,太开心了。

最后的最后,你以为结束了,NO!

该Demo里面的html有空的小朋友可以看一下。

由于项目需求我们是3个参数,在该demo里面执行拿到第一个参数,该demo就运行出错,提示我们数组越界了,在这里真的浪费了好多时间,后来发现他们的demo里面调用两个参数的方法在JS里面声明的方法与OC里面真正的实现方法有点差入,比如OC里面定义的方法

- (void) h5CallApp: (NSString*) param And2: (NSString*) param2 And3: (NSString*) param3

在html里面只能写成

MyJSTest.h5CallAppAnd2And3("param1","param2","param3")。

是不是觉得不可思义,最后我整体看了一下代码,里面好像有这一段在注入JS的时候有用到的

inject: function (obj, methods){

window[obj] = {};

var jsObj = window[obj];

for (var i = 0, l = methods.length; i < l; i++){\\

(function (){

var method = methods[i];

var jsMethod = method.replace(new RegExp(\\":\\", \\"g\\"), \\"\\");

jsObj[jsMethod] = function (){

return EasyJS.call(obj, method, Array.prototype.slice.call(arguments));

};

})();\\

}

}

这个好像是替换方法的,原谅我的无知啊,我也是没看懂,仅仅是感觉与猜测,勿喷我,我真的怕被喷。

最后的最后,JS的那边的开发肯定是不会为了将IOS与安卓开发做区分写代码的,所以我只能在注入JS完成后加了这么一句

[webView stringByEvaluatingJavaScriptFromString:@"test.h5CallApp=test.h5CallAppAnd2And3;"]

这句话的作用是替换JS里面的方法的。

唉,伪程序媛还是无法将一个东西描述得很清楚,不过如果你有更好的方法,请记得告诉我。还有1个多小时就到传说的双11,但是与我有什么关系呢,睡觉吧,晚安,各位。

最后的最后,你们要的Demo来了,希望满意。点我看Demo啦。

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

推荐阅读更多精彩内容